很久之前认识过make,听说很强大的一个功能,但没有充分认识到,知道今天。
下面的实验都是在ubuntu16.04下进行
认识make和makefile
makefile是一种编译脚本,make是解释makefile的命令
makefile编写规则
目标文件:[相依文件…]
命令1[#注释]
…
命令n[#注释]
实例
# cc默认为gcc
objects = main.o readfile.o writefile.o
edit : $(objects)
cc -o edit $(objects)
main.o : main.c readfile.h writefile.h
cc -c main.c
readfile.o : readfile.c readfile.h
cc -c readfile.c
writefile.o : writefile.c writefile.h
cc -c writefile.c
clean :
rm edit $(objects)
上面的脚本,我们可以放在名为makefile或Makefile文件中,在该目录下输入make命令,就可以生成所有的目标文件。
最后要说明一点是clean只不过是一个动作的名字,其冒号后面什么都没有,那么make就不会主动去找文件的依赖性,就不会执行其后所定义的命令。如上,rm edit $(objects)
命令是不会被执行的。当我们需要执行此命令去删除所有生成的目标文件时,可以在此目录下输入make clean,以便重新编译
运行机制大概描述
- make会在当前目录下找名为makefile或Makefile文件
- 若找到,则会将第一个目标文件当作最终为目标文件
- 若当前目录下edit文件不存在,或edit冒号后的依赖文件修改时间要比edit新,则会执行命令生成新的edit
- 当然所有相关的.c和.h文件是必须存在的,否则会报如下错误
实例源代码:
链接: https://pan.baidu.com/s/1qYAsJpE 密码: ijv7
参考:
跟我一起写Makefile-陈皓