Linux工具——make/Makefile

一个工程中的源文件有很多,按照它们的模块,功能和类型,分别放在不同的目录中,Makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译。Makefile带来的好处就是自动化编译,一旦写好只需要一个make命令,就可以完成整个工程的自动编译。

make与Makefile的关系
make是一条命令工具,一个解释Makefile中指令的命令工具,Makefile是一个文件,两个搭配使用完成项目的自动化构建。

Makefile里面放的是依赖关系和依赖方法

提前创建一个hello.c文件
再创建Makefile文件
在这里插入图片描述
打开Makefile文件
Linux工具——make/Makefile_第1张图片
依赖关系:
以上图为例
生成hello文件依赖hello.c
生成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命令之后:

  1. make会在当前目录下查找名叫Makefil或者makefile的文件
  2. 如果找到,它会在找到文件中的第一个目标文件,比如在上面的例子中它会找到hello这个文件,并把这个文件作为最终目标文件。
  3. 如果hello不存在,或者hello所依赖的后面的hello.o文件的文件修改时间比hello这个文件新,那么它就会执行后面定义的命令来生成这个文件。
  4. 如果hello所依赖的文件hello.o不存在,那么make会在当前文件中找目标文件为hello.o文件的依赖性,如果找到再根据那一个规则生成hello.o文件。
  5. 这里C文件和H文件都存在,于是make会生成hello.o文件,然后再用hello.o文件声明make的终极目标,即执行hello文件。
    (这就是整个make的依赖性,make会一层一层的去找文件的依赖关系,直到最后编译出第一个目标文件,在找寻过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会推出,并报错。对于定义的命令错误,或者比阿尼不成功,make是不管的。make就只管文件的依赖性,即如果找在找了依赖关系之后,冒号后面的文件还是不在,那么make就不工作了。)

注意
工程是要被清理的
Linux工具——make/Makefile_第2张图片
像clean 这种,没有被第一个目标文件直接或者间接关联,那么他们后面所定义的命令将不会被自动执行,但是我们可以显示让make执行,即执行命令make clean,以此来清除所有的目标文件,以便重新编译。
一般像clean这种目标文件,我们将它设置为伪目标,用.PHONY修饰,伪目标的特性是:总是被执行。

你可能感兴趣的:(Linux)