文章目录
一个工程中的源文件有很多,按照它们的模块,功能和类型,分别放在不同的目录中,Makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译。Makefile带来的好处就是自动化编译,一旦写好只需要一个make命令,就可以完成整个工程的自动编译。 1 make与Makefile的关系
make是一条命令工具,一个解释Makefile中指令的命令工具,Makefile是一个文件,两个搭配使用完成项目的自动化构建。
2 Makefile里面放的是依赖关系和依赖方法提前创建一个hello.c文件
再创建Makefile文件
打开Makefile文件
hello: hello.o gcc test.o -o test 应该改为: hello: hello.o gcc hello.o -o hello
依赖关系:
以上图为例
生成hello文件依赖hello.o
生成hello.o文件依赖hello.s
生成hello.s文件依赖hello.i
生成hello.i文件依赖hello.c
冒号左侧叫做目标文件
冒号右侧叫做依赖文件列表(有多个依赖文件时,用空格分开)
依赖方法:
gcc hello.* -option hello.*
这里解释一下上图几条依赖方法的意思
预处理(进行宏替换):gcc -E hello.c -o hello.i
选项·-E:让gcc在预处理结束后停止编译过程
选项-o是指目标文件,i文件为已经预处理过的C原始程序
编译(生成汇编):gcc -S hello.i -o hello.s
选项-S查看代码是否规范无误
汇编(生成机器可识别的代码):gcc -c hello.s -o hello.o
汇编阶段将编译阶段生成的.s文件转换成目标文件
选项-c可以看到汇编代码已经转换成.o的二进制目标代码
连接(生成可执行文件或库文件):gcc hello.o -o hello
成功编译后,进入了链接阶段
当我们输入make命令之后:
make会在当前目录下查找名叫Makefil或者makefile的文件
如果找到,它会在找到文件中的第一个目标文件,比如在上面的例子中它会找到hello这个文件,并把这个文件作为最终目标文件。
如果hello不存在,或者hello所依赖的后面的hello.o文件的文件修改时间比hello这个文件新,那么它就会执行后面定义的命令来生成这个文件。
如果hello所依赖的文件hello.o不存在,那么make会在当前文件中找目标文件为hello.o文件的依赖性,如果找到再根据那一个规则生成hello.o文件。
这里C文件和H文件都存在,于是make会生成hello.o文件,然后再用hello.o文件声明make的终极目标,即执行hello文件。
(这就是整个make的依赖性,make会一层一层的去找文件的依赖关系,直到最后编译出第一个目标文件,在找寻过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会推出,并报错。对于定义的命令错误,或者比阿尼不成功,make是不管的。make就只管文件的依赖性,即如果找在找了依赖关系之后,冒号后面的文件还是不在,那么make就不工作了。)