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的自动变量

变量符号 含义
$@ 目标
$^ 目标依赖
$< 目标依赖列表的第一个依赖
$? 所有目标依赖中被修改的文件
hmoban主题是根据ripro二开的主题,极致后台体验,无插件,集成会员系统
自学咖网 » Makefile学习笔记