工程管理器-make
make是一个自动编译管理器,能够根据文件时间戳自动发现更新过的文件从而减少编译的工作量,同时,它通过读入Makefile文件的内容来执行大量的编译工作,用户只需要编写一次简单的编译语句即可。
1. Makefile基本结构
Makefile用来告诉make如何编译和链接一个程序,它是make读入的唯一配置文件。
Makefile中最重要的元素-规则。
规则的语法:
Target: prerequisites
@commands
Target: 目标文件,可执行文件或是一个标签
Prerequisites:要创建目标体所依赖的文件,或者是其他目标
Command:创建每个目标体时需要的运行的命令
Note:
1)command前的@是表示不打印出命令
2)command前必须要有一个“Tab”符
2. Makefile中变量
Makefile中的变量使用格式为$(VAR)
1. 变量赋值
1)递归扩展方式:在引用该变量时进行替换,即如果该变量包含了对其他变量的引用,则在引用该变量时递归地将内嵌的变量全部展开。形如:
objects = main.o foo.o bar.o utils.o
2)简单扩展方式:递归扩展方式定义的变量存在一个严重的缺点,就是不能在变量后面追加内容,因为语句“CFLAGS = $(CFLAGS) -O”在变量扩展中可能导致无限循环。为了避免这种问题发生,引入简单扩展方式;变量赋值,make只对其进行一次扫描和替换。形如:
objects := $(objects) another.o
3)其他赋值方式
条件赋值: 当变量以前没有定义时,就定义它并且将右边的值赋值给它,如果已经定义了那么就不再改变其值。形