飞道的博客

【Linux】项目自动化构建工具-make/Makefile的使用

441人阅读  评论(0)

目录

前言

依赖

依赖关系

依赖方法

使用

项目清理


前言

🎐在使用 Linux 的时候应该已经察觉到,在 Linux 环境下我们会有非常多的源文件,并且在使用前还需要手动编译,在使用的时候就会变得非常地麻烦。

🎐但 make/Makefile 的出现就解决这些问题, Makefile 定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。 Makefile 带来的好处就是——“自动化编译”,一旦写好,只需要一个 make 命令,整个工程完全自动编译,极大的提高了软件开发的效率。

🎐同时,值得注意的一点是, make 是使用时输入的命令,而 Makefile 是一个文件里面包含了构建编译所需要的一系列规则。

依赖

🎐使用 make/Makefile 完成一件事情的前提就是需要正确的依赖关系+正确的依赖方法。

依赖关系

🎐可以简单的理解为,文件1来源于文件2则说明文件1依赖于文件2。例如我要得到可执行文件 text ,在那之前我必须先要有作为源文件的 text.c 才能对其进行编译进而得到 text ,便称 text 依赖于 text.c 

依赖方法

🎐依赖方法就是在依赖的关系之上将二者进行连接的方法,还是上面的例子,我们知道了 text 依赖于 text.c ,那二者之间的依赖方法就是通过 gcc 进行编译的命令 gcc -o text text.c 了。

使用

🎐为了方便理解将编译链接的各各步骤拆分出来进行讲解。


  
  1. text:text.o / /text依赖于text.o
  2. gcc -o text text.o
  3. text.o:text.s / /text.o依赖于text.s
  4. gcc -c -o text.o text.s
  5. text.s:text.i / /text.s依赖于text.i
  6. gcc -S -o text.s text.i
  7. text.i:text.c / /text.i依赖于text.c
  8. gcc -E -o text.i text.c
  •  make 会在当前目录下找名字叫 Makefile 或 makefile 的文件(要自己创建)。如果找到,它会找文件中的第一个目标文件,在上面的例子中,他会找到 text 这个文件,并把这个文件作为最终的目标文件。
  • 如果 text 文件不存在,或是 text 所依赖的后面的 text.o 文件的文件修改时间要比 text 这个文件新,那么,他就会执行后面所定义的命令来生成 text 这个文件。
  • 如果 text 所依赖的 text.o 文件不存在,那么 make 会在当前文件中找目标为 text.o 文件的依赖性,如果找到则再根据那一个规则生成 text.o 文件。(这有点像一个堆栈的过程)
  • 你的C文件和H文件是存在的,于是 make 会生成 text.o 文件,然后再用 text.o 文件声明
  • make 的最终任务,就是得到可执行文件 text 
  • make 会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
  • 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么 make 就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make 根本不管。
  • make 只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,就会停止运行。

项目清理

🎐如上的使用make之后会生成 make.i make.s make.o make 四个文件,每次都输入一长串命令去删除未免过于麻烦,可以将删除项目文件也并入 Makefile 之中。


  
  1. .PHONY: clean
  2. clean:
  3. rm -f text.i text.s text.o

 🎐.PHONYmake/Makefile语法中的一个关键字,代表的意思是:总是被执行的。举个例子,当我们使用 make 生成 text 之后上一次修改 text.c 的时间仍晚于 text 且再次使用 make 则不会生成新的 text 


  
  1. [Alpaca@VM- 12- 9-centos myfile]$ make
  2. gcc -o text text.c
  3. [Alpaca@VM- 12- 9-centos myfile]$ make
  4. make: `text ' is up to date.
  5. [Alpaca@VM-12-9-centos myfile]$ make
  6. make: `text' is up to date.

 🎐若是将text也并入 .PHONY 之中这个命令就是总是被执行的,有以下两种写法可以自由选择。


  
  1. .PHONY: clean text
  2. text:text.o / /text依赖于text.o
  3. gcc -o text text.o
  4. text.o:text.s / /text.o依赖于text.s
  5. gcc -c -o text.o text.s
  6. text.s:text.i / /text.s依赖于text.i
  7. gcc -S -o text.s text.i
  8. text.i:text.c / /text.i依赖于text.c
  9. clean:
  10. rm -f text.i text.s text.o

  
  1. .PHONY: text
  2. text:text.o / /text依赖于text.o
  3. gcc -o text text.o
  4. text.o:text.s / /text.o依赖于text.s
  5. gcc -c -o text.o text.s
  6. text.s:text.i / /text.s依赖于text.i
  7. gcc -S -o text.s text.i
  8. text.i:text.c / /text.i依赖于text.c
  9. gcc -E -o text.i text.c
  10. .PHONY: clean
  11. clean:
  12. rm -f text.i text.s text.o

🎐精简之后就是这个样子的。


  
  1. text:text.c / /text依赖于text.c(依赖关系)
  2. gcc -o text text.c / /使用gcc对text进行编译链接得到text.c(依赖方法)
  3. .PHONY: clean / /clean总是被执行
  4. clean: / /clean也是一个文件且不依赖于其他文件(依赖关系)
  5. rm -f text / /通过rm删除可执行文件(依赖方法)

 在make/Makefile的帮助下可以有效地提升 Linux 的使用效率,好了,这次 gcc 的介绍就到这里结束了,关注博主共同进步!!


转载:https://blog.csdn.net/Lin_Alpaca/article/details/128826979
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场