Linux项目自动化构建工具make/Makefile

Linux项目自动化构建工具make/Makefile_第1张图片

  

本文已收录至《Linux知识与编程》专栏!
作者:ARMCSKGT
演示环境:CentOS 7 

   


目录

前言

正文 

makefile文件与语法规则

make指令与执行逻辑

makefile任务刷新策略

.PHONY修饰为伪目标

最后


前言

会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力,一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的,规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。
make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建

Linux项目自动化构建工具make/Makefile_第2张图片


正文 

makefile是一个围绕依赖关系和依赖方法构建的一个自动化编译工具!


makefile文件与语法规则


make指令的执行是以makefile文件存在为基础的,如果没有makefile则make指令无法执行!

Linux项目自动化构建工具make/Makefile_第3张图片 没有makefile文件make指令被迫停止

 makefile文件中写入任务,这些任务是由依赖关系+依赖方法构成和实现的!

依赖关系 = 目标对象 + 执行文件(执行对象)

依赖方法:处理执行对象产生目标对象的方法!


makefile语法格式:

目标对象:执行文件(执行文件) //依赖关系
    依赖方法(实现方法) //一般方法前面空格

Linux项目自动化构建工具make/Makefile_第4张图片

 如图,exe可执行程序的产生依赖与test.c文件,而exe可执行程序的产生方法(也就是依赖方法)是利用gcc去编译并自定义名称为exe最终产生exe可执行程序,这样就完成了一个任务的构建,一个makefile文件中可以写很多任务

  

当然有些目标对象可能不需要执行文件这种半缺失的任务写法也是合理的,,例如我们自己写的clean清理任务,实现自动化清理产生的可执行程序exe同时也可以有多个执行文件(多个执行文件之间使用隔开),例如声明与定义分离时我们需要所有文件一起编译产生可执行程序

  

所以目标对象并不是一定会产生(或者说目标对象只是为了达成某种目的)可以说目标对象也是任务名!执行这个任务可能会产生对象,具体的看任务的目的和实现方法,而且产生的对象名也不一定和目标对象相同,也可以不同!这个可以依据个人喜好和公司规定进行设置!

  

这样每次我们修改完代码,就可以使用make指令进行exe程序的编译,测试完后立刻清除,在以后的项目编写中会有很多个任务,如果一句一句的通过指令执行效率太低,所以我们会经常使用到makefile提高效率!


makefile注释符

 

在makefile中,需要注释某些语句时可以使用:#注释语句

Linux项目自动化构建工具make/Makefile_第5张图片


$@$^代替依赖关系对象

 

我们在前面说过:依赖关系 = 目标对象 : 执行文件

那么在编程时,如果我们有一些参数经常需要替换,而不修改代码,经常使用的是宏定义,宏定义的原理是直接替换!

在makefile中,如果我们需要经常更换目标对象和执行文件,就可以使用$@代替目标对象,使用$^代替执行文件,这样每次我们只需要修改依赖关系而不修改依赖方法就完成make任务的执行目标!其原理就是C语言的宏替换!

Linux项目自动化构建工具make/Makefile_第6张图片

Linux项目自动化构建工具make/Makefile_第7张图片 执行命令时被自动替换

make指令与执行逻辑


make调用makefile中的某一条任务指令:

make [目标对象]

make调用目标对象任务后会生成目标对象,并显示执行的方法(命令)!

Linux项目自动化构建工具make/Makefile_第8张图片

 注意:如果我们执行make指令还没没有写目标对象,则make会默认执行makefile文件中第一个任务,后面的其他任务不会执行!只有我们使用make指令并指定任务的目标对象make才会执行指定的任务产生目标对象!

Linux项目自动化构建工具make/Makefile_第9张图片


可能会有人想到说,makefile文件如果写成Makefile会有影响吗?两个都存在怎么办?

makefile和Makefile两个文件都可以被make指令识别和执行,当两个文件都存在时make会优先选择makefile文件去执行!

Linux项目自动化构建工具make/Makefile_第10张图片


如果我们的make指令在执行方法,发现执行文件不存在时会在文件中向下在其他任务中去寻找,找到了则先执行对应任务获取自己所需要的执行文件,然后再执行本任务!其中的原理是依赖栈实现的,所以类似于函数调用,一层一层开辟栈帧。

Linux项目自动化构建工具make/Makefile_第11张图片

Linux项目自动化构建工具make/Makefile_第12张图片

 当然,在过程中产生的所需目标对象也会保留在目录中!

Linux项目自动化构建工具make/Makefile_第13张图片

 makefile中依赖方法也不一定只能写一句,可以写多句,例如我们不需要预处理编译等文件,可以产生对象并使用后就立刻删除,而且所以这么多逻辑可以规整为一个依赖方法!

Linux项目自动化构建工具make/Makefile_第14张图片


makefile任务刷新策略


在makefile中,如果目标任务的执行可以产生目标对象,则执行文件如果没有修改,再次执行make指令会报错,因为make会判断文件是否被修改(判断修改时间),如果被修改才允许更新目标对象!

Linux项目自动化构建工具make/Makefile_第15张图片

Linux项目自动化构建工具make/Makefile_第16张图片

 这时如果我们对源文件进行修改,或者touch一下修改源文件的修改时间就能再次使用make指令!


 .PHONY修饰为伪目标


.PHONY是makefile文件中的一个关键字,表示对某个目标对象产生伪目标,这样无论目标对象的执行文件是否被修改,都可以重复执行这个任务!

Linux项目自动化构建工具make/Makefile_第17张图片

被.PHONY修饰的任务可以无视任务刷新策略,重复执行这个任务!

 

这个关键字一般用来修饰clean清理任务!我们每次生成可执行程序,再删除,重复执行是非常合理的;当然其他场景下如果需要也可以修饰!


最后

makefile的知识介绍到这里就结束了,相信了解完的朋友们一定有了很多套make任务列表来加速自己的开发;通过makefile极大的提高了我们的开发效率,是我们不可缺少的工具之一!

本次Linux编译器gcc/g++的基本知识就介绍到这里啦,希望能够尽可能帮助到大家。

如果文章中有瑕疵,还请各位大佬细心点评和留言,我将立即修补错误,谢谢!

 其他文章阅读推荐

Linux基础指令-CSDN博客

Linux权限的基本知识-CSDN博客

Linux编辑器vim-CSDN博客

欢迎读者多多浏览多多支持!

你可能感兴趣的:(Linux知识与编程,自动化,运维,linux)