GUN Make学习笔记

make工程管理器

一、make概述

目的:

在大型项目开发中,利用make工具自动完成编译工作,以避免多次手工键入GCC命令进行编译。

功能:

1、如果仅修改了某几个源文件,则只重新编译这几个源文件。

2、如果某个头文件被修改了,则重新编译所有包含该头文件的源文件。

3、如果工程中有几个c文件没被编译,则编译并连接这几个c文件。

方式:

通过一个称为makefile的文件来完成并自动维护编译工作。

文件主要内容:

定义了源文件之间的依赖关系,说明了如何编译各个源文件并连接生成可执行文件。    

优点:

自动化编译,一旦写好,只需要一个make命令,即可自动编译整个工程,提高软件开发的效率。


二、makefile基本结构

2.1makefile文件内容

1)make工具创建的目标体,通常是目标文件或可执行文件。

2)要创建的目标体所依赖的文件

3)创建每个目标体时需要运行的命令

格式为:

target:dependency_files

<tab>command

需要执行makefile时,只需要在命令行中输入make即可。

2.2 makefile执行原理

示例:

工程中有一个头文件和五个c文件。

a.c  b.c  d.c  e.c  program.c   main.h

其中main.h包含a.c/b.c/d.c/e.c并在program.c源文件中被调用。

则makefile文件内容为:

#makefile

program:main.o a.o b.o d.o e.o

gcc main.o a.o b.o d.o e.o -o program

main.o:main.c main.h 

gcc -c main.c -o main.o

a.o:a.c

gcc -c a.c -o a.o

b.o:b.c

gcc -c b.c -o b.o

d.o:d.c

gcc -c d.c -o d.o

e.o:e.c

gcc -c e.c -o e.o

clean:

rm *.o program

要点:

1)#以后为注释,一行如果不够,使用反斜杠“\”续写。

2)make命令需要在makefile文件目录下执行。

3)要删除执行文件和所有的中间目标文件,执行make clean命令。

4)依赖关系可以理解为目标文件由哪些依赖文件生成,换言之,目标文件是哪些文件更新的结果。

5)执行过程为:命令行输入make后,首先在当前目录下找到“makefile”文件或者“makefile”文件夹里的文件。找到第一个目标文件(这里目标文件为第一行的program)。由于当前目录下所依赖的文件main.o不存在,因此在文件中查找main.o的依赖文件。由于当前目录下存在main.c和main.h文件,因此执行目标体运行的命令gcc -c main.c -o main.o以此类推直到可以生成program文件为止。

6)注意:在找寻过程中,如果出现错误,如最后被依赖的文件不存在,make就会直接退出并报错。而对于所定义的命令的错误,或是编译不成功,make就不会处理。

7)命令行中执行make命令时,即使依赖文件存在,make也会自动对比目标文件和依赖文件的修改日期。如果依赖文件的修改日期比目标文件的更新,make也会重新执行目标体运行的命令。

8)上述执行的过程为(理解为寻找依赖关系):

gcc -c main.c -o main.o

gcc -c a.c -o a.o

gcc -c b.c -o b.o

gcc -c d.c -o d.o

gcc -c e.c -o e.o


三、makefile变量

解决问题:

在大型项目中,如果需要在makefile文件中删除、添加或修改某个多次引用的文件(如*.o),则容易遗忘或者编写过程乏味。采用变量的方式可以很好的解决这类问题。

变量定义方式

1)递归展开方式:即变量一次展开后,如果还包含其他变量,则继续展开,即变量的嵌套。格式为VAR=var

2)简单扩展方式:即变量只展开一次。格式为:VAR:=var

变量引用方式:$(VAR)

变量类型:分为用户自定义变量、预定义变量、自动变量及环境变量。

用户自定义变量,如:

objects=main.o a.o b.o d.o e.o

program:$(objects)

gcc $(objects) -o program

预定义变量:

包含了常见编译器、汇编器的名称及其编译选项。如CC为C编译器的名称,默认值为cc,在宿主机中进行开发调试时采用其他编译器进行编译,当需要移植到其他架构的目标机器上时,需要修改,如这里修改为CC=gcc,以实现交叉编译过程。

自动变量:

用于简化编译语句中包含的目标文件和依赖文件。

命令格式含义
$*不包含扩展名的目标文件名称
$+所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件
$<第一个依赖文件的名称
$?所有时间戳比目标文件晚的依赖文件,并以空格分开
$@目标文件的完整名称
$^所有不重复的依赖文件,以空格分开
$%如果目标是归档成圆,则该变量表示目标的归档成员名称

环境变量:

如果用户在makefile中定义了与环境变量相同名称的变量,那么用户自定义变量将会覆盖同名的环境变量。


四、makefile规则

1.隐式规则

隐式规则如C编译:“.c”变为“.o”的隐式规则为:$(CC)-c $(CPPFLAGS) $(CFLAGS)

则上述示例中可以省略main.c、a.c、b.c、d.c、e.c的编译命令。

2.模式规则

可以自己定义规则。

















摘自http://www.linuxsir.org/main/doc/gnumake/GNUmake_v3.80-zh_CN_html 由徐海兵老師翻译整理。 本文比较完整的讲述GNU make工具,涵盖GNU make的用法、语法。同时重点讨论如何为一个工程编写Makefile。作为一个Linux程序员,make工具的使用以及编写Makefile是必需的 目 录 第一章:概述 1.1 概述 1.2 准备知识 第二章:GNU make 介绍 2.1 Makefile简介 2.2 Makefile规则介绍 2.3 简单的示例 2.4 make如何工作 2.5 指定变量 2.6 自动推导规则 2.7 另类风格的makefile 2.8 清除工作目录过程文件 第三章:Makefile 总述 3.1 Makefile的内容 3.2 makefile文件的命名 3.3 包含其它makefile文件 3.4 变量 MAKEFILES 3.5 变量 MAKEFILE_LIST 3.6 其他特殊变量 3.7 makefile文件的重建 3.8 重载另外一个makefile 3.9 make如何解析makefile文件 3.9.1 变量取值 3.9.2 条件语句 3.9.3 规则的定义 3.10 总结 第四章:Makefile的规则 4.1 一个例子 4.2 规则语法 4.3 依赖的类型 4.4 文件名使用通配符 4.4.1 统配符使用举例 4.4.2 通配符存在的缺陷 4.4.3 函数wildcard 4.5 目录搜寻 4.5.1 一般搜索(变量VPATH) 4.5.2 选择性搜索(关键字vpath) 4.5.3 目录搜索的机制 4.5.4 命令行和搜索目录 4.5.5 隐含规则和搜索目录 4.5.6 库文件和搜索目录 4.6 Makefile伪目标 4.7 强制目标(没有命令或依赖的规则) 4.8 空目标文件 4.9 Makefile的特殊目标 4.10 多目标 4.11 多规则目标 4.12 静态模式 4.12.1 静态模式规则的语法 4.12.2 静态模式和隐含规则 4.13 双冒号规则 4.14 自动产生依赖 第五章:规则的命令 5.1 命令回显 5.2 命令的执行 5.3 并发执行命令 5.4 命令执行的错误 5.5 中断make的执行 5.6 make的递归执行 5.6.1 变量MAKE 5.6.2 变量和递归 5.6.3 命令行选项和递归 5.6.4 -w选项 5.7 定义命令包 5.8 空命令 第六章:Makefile中的变量 6.1 变量的引用 6.2 两种变量定义(赋值 ) 6.2.1 递归展开式变量 6.2.2 直接展开式变量 6.2.3 如何定义一个空格 6.2.4 “?=”操作符 6.3 变量的高级用法 6.3.1 变量的替换引用 6.3.2 变量的套嵌引用 6.4 变量取值 6.5 如何设置变量 6.6 追加变量值 6.7 override 指示符 6.8 多行定义 6.9 系统环境变量 6.10 目标指定变量 6.11 模式指定变量 第七章:Makefile的条件执行 7.1 一个例子 7.2 条件判断的基本语法 7.2.1 关键字“ifeq” 7.2.2 关键字“ifneq” 7.2.3 关键字“ifdef” 7.2.4 关键字“ifndef” 7.3 标记测试的条件语句 第八章:make的内嵌函数 8.1 函数的调用语法 8.2 文本处理函数 8.2.1 $(subst FROM,TO,TEXT) 8.2.2 $(patsubst PATTERN,REPLACEMENT,TEXT) 8.2.3 $(strip STRINT) 8.2.4 $(findstring FIND,IN) 8.2.5 $(filter PATTERN…,TEXT) 8.2.6 $(filter-out PATTERN...,TEXT) 8.2.7 $(sort LIST) 8.2.8 $(word N,TEXT) 8.2.9 $(wordlist S,E,TEXT) 8.2.10 $(words TEXT) 8.2.11 $(firstword NAMES…) 8.3 文件名处理函数 8.3.1 $(dir NAMES…) 8.3.2 $(notdir NAMES…) 8.3.3 $(suffix NAMES…) 8.3.4 $(basename NAMES…) 8.3.5 $(addsuffix SUFFIX,NAMES…) 8.3.6 $(addprefix PREFIX,NAMES…) 8.3.7 $(join LIST1,LIST2) 8.3.8 $(wildcard PATTERN) 8.4 foreach 函数 8.5 if 函数 8.6 call函数 8.7 value函数 8.8 eval函数 8.9 origin函数 8.10 shell函数 8.11 make的控制函数 8.11.1 $(error TEXT…) 8.11.2 $(warning TEXT…) 第九章:执行make 9.1 指定makefile文件 9.2 指定终极目标 9.3 替代命令的执行 9.4 防止特定文件重建 9.5 替换变量定义 9.6 使用make进行编译测试 9.7 make的命令行选项 第十章:make的隐含规则 10.1 隐含规则的使用 10.2 make的隐含规则一览 10.3 隐含变量 10.3.1 代表命令的变量 10.3.2 命令参数的变量 10.4 make隐含规则链 10.5 模式规则 10.5.1 模式规则介绍 10.5.2 模式规则示例 10.5.3 自动化变量 10.5.4 模式的匹配 10.5.5 万用规则 10.5.6 重建内嵌隐含规则 10.6 缺省规则 10.7 后缀规则 10.8 隐含规则搜索算法 第十一章:使用make更新静态库文件 11.1 库成员作为目标 11.2 静态库的更新 11.2.1 更新静态库的符号索引表 11.3 make静态库的注意事项 11.4 静态库的后缀规则 第十二章 : GNU make的特点 12.1 源自System v的特点 12.2 源自其他版本的特点 12.3 GNU make自身的特点 第十三章 和其它版本的兼容 第十四章 Makefile的约定 14.1 基本的约定 14.2 规则命令行的约定 14.3 代表命令变量 14.4 安装目录变量 14.5 Makefile的标准目标名 14.6 安装命令分类 第十五章 make的常见错误信息   附录:关键字索引 1. GNU make可识别的指示 符 2. GNU make函数 3. GNU make的自动化变量 4. GNU make环境变量 后序
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值