会不会写makefile,从⼀个侧⾯说明了⼀个⼈是否具备完成⼤型⼯程的能⼒

⼀个⼯程中的源⽂件不计数,其按类型、功能、模块分别放在若⼲个⽬录中,makefile定义了⼀系列的规则来指定,哪些⽂件需要先编译,哪些⽂件需要后编译,哪些⽂件需要重新编译,甚⾄于进⾏更复杂的功能操作 makefile带来的好处就是⸺“⾃动化编译”,⼀旦写好,只需要⼀个make命令,整个⼯程完全⾃动编译,极⼤的提⾼了软件开发的效率。

make是⼀个命令⼯具,是⼀个解释makefile中指令的命令⼯具,⼀般来说,⼤多数的IDE都有这个命令,⽐如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可⻅,makefile都成为了⼀种在⼯程⽅⾯的编译⽅法。

基本使用:

myproc.c文件
#include 
int main(){
printf("hello Makefile!\n");return 0;
}
Makefile⽂件
myproc:myproc.c
gcc -o myproc myproc.c
.PHONY:clean
clean:
rm -f myproc
依赖关系
上⾯的⽂件myproc,它依赖myproc.c 
依赖⽅法
gcc -o myproc myproc.c  ,就是与之对应的依赖关系 
项⽬清理
clean:⼯程是需要被清理的
.PHONY:让make忽略源⽂件和可执⾏⽬标⽂件的M时间对⽐ 

编译命令:make,清除命令make clean 为什么make就能直接执行编译文件,清除为什么需要make clean命令呢? make在执行时默认执行第一个,除非明确指出make clean,才会去执行

makefile的工作原理: 1. make会在当前⽬录下找名字叫“Makefile”或“makefile”的⽂件。

2. 如果找到,它会找⽂件中的第⼀个⽬标⽂件(target),在上⾯的例⼦中,他会找到 myproc 这个⽂件,并把这个⽂件作为最终的⽬标⽂件。

3. 如果 myproc ⽂件不存在,或是 myproc 所依赖的后⾯的 myproc.o ⽂件的⽂件修改时间要这个myproc
⽂件新(可以⽤ touch 测试),那么,他就会执⾏后⾯所定义的命令来⽣成这个myproc⽂件。

4.如果 myproc 所依赖的 myproc.o ⽂件不存在,那么 make 会在当前⽂件中找⽬标为myproc myproc.o ⽂件的依赖性,如果找到则再根据那⼀个规则⽣成 myproc.o ⽂件。(这有点像⼀个堆栈的过程)

5. 当然,你的C⽂件和H⽂件是存在的啦,于是 make 会⽣成 myproc.o ⽂件,然后再⽤ myproc.o ⽂件声明 make 的终极任务,也就是执⾏⽂件 hello 了。

6. 这就是整个make的依赖性,make会⼀层⼜⼀层地去找⽂件的依赖关系,直到最终编译出第⼀个⽬标⽂件。

7. 在找寻的过程中,如果出现错误,⽐如最后被依赖的⽂件找不到,那么make就会直接退出,并报错,⽽对于所定义的命令的错误,或是编译不成功,make根本不理。make会⼀层⼜⼀层地去找⽂件的依赖关系,直到最终编译出第⼀个⽬标⽂件。

扩展语法:

以变量的形式去编辑makefile

$@:目标文件

$^:众多文件列表

带上@:就不会回显命令

%.o:%.cpp

$<:将%.c和%.cpp依次展开

$(shell ls *.cpp)获取ls命令中匹配*.cpp的文件

$(SRC:.cpp=.o):将SRC中.cpp换成.o

makefile就介绍到这里,如有错误欢迎指出,谢谢!!!