Makefile学习笔记
1. makefile简单介绍:
▶ Windows系统里的 Visual studio/Dev C++等IDE工具(Integrated Development Environment)将C语言的预处理、编译、汇编、链接等过程集成在一起,而在Linux系统下需要编写GCC命令才能完成编译操作。当项目文件很多时,效率太低了。因此采用Makefile的方法实现编译的统一管理。
2. makefile的规则
目标
:目标依赖
命令
目标是最终想要的文件,一般为可执行文件
;目标依赖是生成可执行文件所依赖的文件
;命令一般为GCC命令
、shell命令
、链接命令
、objcopy命令
等。
目标的概念 | 解释 |
---|---|
默认目标 | 当我们在make编译时没有给make指定要生成的目标,make就会选择Makefile文件中的第一个目标作为默认目标 |
多目标 | 一个规则中也可以有多个目标,多个目标具有相同的生成命令和依赖文件 %.o:%.c |
伪目标 | 有时候我们设置一个目标,并不是真正生成这个文件,如上面的clean目标,而是仅仅为了执行某个操作。例如.PHONY clean |
3. makefile的目标依赖
makefile通过比较目标依赖文件和目标文件的更新时间,当依赖文件更新后,目标文件才会随着编译更新。
但有一个问题,目标依赖文件中的头文件更新不会被记录到,导致目标文件不会更新。这个问题可以通过gcc-M hello.c这个命令解决。
[xuanmiao@localhost Demo_makefile]$ gcc -M hello.c
hello.o: hello.c /usr/include/stdc-predef.h hello.h
4. makefile的自动变量
变量符号 | 含义 |
---|---|
$@ | 目标 |
$^ | 目标依赖 |
$< | 目标依赖列表的第一个依赖 |
$? | 所有目标依赖中被修改的文件 |