1. makefile 简介
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 clean
3.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