makefile 是一个类似shell脚本的自动化编译工具。Makefile 文件描述了整个工程的编译、连接等规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。
makefile 存在意义在于提高代码部署、调试、运行效率。试想一下,源文件(src)下存在成千上百 .cpp文件,每次调试都需要按照(一)中方式:g++ -c ......,对于开发人员来说,将及其不便。makefile 配置好更新运行规则,只需要相应文件夹下直接make完成。
2. makefile使用-
make命令可识别的文件为:makefile 或者 Makefile
-
makefile 基本格式
# 目标列表 : 依赖列表
# tab 命令
....
target...:depends...
command(shell)
....
# 规则2
3. makefile变量
4. makefile 模式匹配规则
注意: 5. makefile 函数
3 实例 3.1 基本结构
tree # 文件目录 ├── head.cpp ├── head.h └── main.cpp # 文件内容见(二) # 当前目录下创建makefile文件 touch makefile # 编辑 vim makefile # 编辑完成后 make #查看 tree ├── head.cpp ├── head.h ├── main ├── main.cpp └── makefile #运行 ./main
makefile 文件内容
#目标文件:main 依赖 head.cpp main.cpp
main:head.cpp main.cpp
g++ head.cpp main.cpp -o main
3.2 完整链接makefile
makefile 文件内容
# 添加完整链接过程 # 规则1:为总输出规则,下面规则服务规则1 main:head.o main.o g++ head.o main.o -o main #规则2 head.o:head.cpp g++ -c head.cpp -o head.o #规则3 main.o:main.cpp g++ -c main.cpp -o main.o
运行机制同(3.1)操作。此时会多生成中间目标文件head.o,main.o。可以继续优化,比如运行完成后我们不需要保留.o文件,对于类似规则期望一条命令实现所有(模式匹配)。这里就涉及makefile的变量规则。
3.3 makefile 模式匹配makefile 文件内容
# 添加完整链接过程 # 定义变量 src=head.o main.o target=main # 规则1:为总输出规则,下面规则服务规则1 $(target):$(src) $(CXX) $(src) -o $(target) #规则1-n %.o:%.c $(CXX) -C $< -O $@ #清除.o clean: rm $(src)
#清除命令 make clean3.4 makefile 函数
# 添加完整链接过程 # 定义变量 应用函数 src=$(wildcard ./*.cpp) #head.cpp main.cpp objs=$(patsubst %.cpp, %.o, $(src)) target=main # 规则1:为总输出规则,下面规则服务规则1 $(target):$(objs) $(CXX) $(objs) -o $(target) #规则1-n %.o:%.c $(CXX) -c $< -o $@ #清除.o #伪目标 .PHONY:clean clean: rm $(objs) -f
注意:这里运行编辑都是终端操作的
# 编辑工具:vim cd 当前文件夹 # 按要求写入规则 vim makefile # ESC:wq # 运行 make # 测试查看(这里生成的可执行文件为main) ./main # 清除.o make clean



