makefile
make命令:负责c/c++程序编译与链接
- make根据指定命令进行建构
- 建构规则文件:GNUmakefile , makefile,Makefile
makefile 文件格式
makefile 语法
--基本语法,变量,条件判断,循环,函数
makefile 文件的基本格式
target...:prerequisites...
[tab键] commands
makefile文件的规则
- makefile 文件由一系列规则构成
- 规则目的:建构目标的先决条件是什么以及如何构建目标
- 如果没有指定目标,缺省执行第一个目标
- 若prerequisites中有一个以上的文件比target文件要新,执行commands所定义的命令
target:目标
- 通常为编译期的文件名,以指定要建构的对象,也可以是执行文件,还可以是标签(操作名称,伪目标)
- 可以是单一目标,也可以为空格分隔的多个目标
- 每个目标都定义了一组处理规则,和其相关规则构成规则链
prerequisites:先决条件
- 为生成该目标所需要的先决文件或者目标(前置条件)
- 一般为空格分隔的文件名,指定目标是否重建的判断标准,即只要有一个先决条件不存在或者有过更新,就需要重建目标
prerequisites:先决条件
若目标先决条件本身需要重建,则匹配该先决条件的目标,执行其对应的命令
commands:命令
由一行或者多行shell命令组成,命令前有Tab键
指示如何建构目标,一般为生成目标文件
每行命令都在单独的进程中执行,彼此没有继承关系,不能简单传递数据;解决办法是:用分号将多条命令书写在单行(此时可用“”折行),或者为该条规则添加指示“.ONESHELL:”
伪目标:操作名称,而不是文件名
- 删除编译后的二进制目标文件,例如:
clean:
rm -f *.o
执行命令时需指定伪目标:$make clean
若当前目录下有clean文件,则此规则不会被执行;此时可用“.PHONY:clean”明确指示clean为伪目标;
make将跳过文件检查,执行其对应的命令
执行清除任务的伪目标一般放在脚本的最后
伪目标惯例
- all:所有目标的目标,一般为编译后所有的目标,对同时编译多个程序很有用
- clean:删除由make创建的文件
- install:安装已编译好的程序,主要任务是完成目标文件的拷贝
- print:列出改变过的源文件
- tar:打包备份源文件,形成tar文件
- dist:创建压缩文件,一般将tar文件压缩成Z文件或者gz文件
- TAGS:更新所有的目标,以备完整地重新编译使用
- check和test:一般用来测试makefile的流程
例子:假设程序主文件为:main.c,使用library库
#注释行
prog:main.o library.o
cc -o prog main.o library.o
main.o: main.c library.h
cc -c main.c
library.o:library.c library.h
cc -c library.c
.PHONY:clean
clean:
rm main.o library.o
接下里:make(生成prog)
make clean