【Linux杂货铺】自动化构建工具 Makefile

【Linux杂货铺】自动化构建工具 Makefile_第1张图片

博主:代码菌@-CSDN博客

专栏:Linux杂货铺_代码菌@的博客-CSDN博客


目录

前言

makefile和make的概念

示例

依赖关系 and 依赖方法

项目清理

make 工作原理

扩展

总结


前言

        一个工程的源文件不计其数,按照不同功能分在若干目录中,如何有规则的处理这些文件,提高开发效率呢?就需要自动化编译工具makefile,make则是一个命令工具,解释makefile中指令的工具。

        两者搭配使用,完成自动化构建。会不会写makefile,从一个侧面说明了一个人是否具备大型工程的能力。

makefile和make的概念

        ● makefile定义了系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。

        makefile带来的好处就是“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。

(例如,我们就不需在每个源文件写完后 都 [-gcc 参数] 了。)

          ● make 是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Visual C++中的nmake,Linux下GNU的make。可见makefile成为了一种在工程方面的编译方法。

        简而言之,makefile是一个文件,定义了规则;make是一条指令,负责解释规则。两者搭配使用,完成项目的自动化构建。

示例

        我们直接来看一个例子,写一个 .c 文件,打印 " hello world "。

【Linux杂货铺】自动化构建工具 Makefile_第2张图片

        以上,我们通过Linux下vim工具,写了code.c的源文件,如果不使用makefile,那我们就需要在窗口下gcc了

【Linux杂货铺】自动化构建工具 Makefile_第3张图片

        写这么多参数,想必你也烦了,那我们就来看看makefile如何简略这些吧。

● 首先,我们要先创建一个makefile原件。

【Linux杂货铺】自动化构建工具 Makefile_第4张图片

● 其次,我么通过vim工具来编译makefile文件。

【Linux杂货铺】自动化构建工具 Makefile_第5张图片

        这里,我们下部深入理解,下面我们会一一讲解,这知道makefile里面有这些内容即可。

● 最后我们直接输入系统界面下 make 即可,成功创建code.exe。想要删除,输入make clean。

【Linux杂货铺】自动化构建工具 Makefile_第6张图片【Linux杂货铺】自动化构建工具 Makefile_第7张图片

        接下来,依次讲解makefile里面的内容分别代表什么含义。

依赖关系 and 依赖方法

【Linux杂货铺】自动化构建工具 Makefile_第8张图片

        字面含义,即上面的code.exe依赖code.c ; 而gcc.. 就是对用的依赖关系。依赖关系可以有多行。依赖文件列表按空格分开,可以为空。

项目清理

        工程是需要处理的,像clean这种,没有被第一个目标文件直接管理或间接关联,那么它后面所定义的命令就不会被自动执行。

        不过,我们可以显示要make执行,即命令," make clean " 以此来清除所有的目标文件,已重新编译。

        但一般这种clean的目标文件,设置为伪目标,即 .PHONY 修饰,伪目标特性是,总是被执行。

        如果我们已经make创建了文件,就不不能再次创建了。

【Linux杂货铺】自动化构建工具 Makefile_第9张图片

make 工作原理

● make会在当前目录下找名字为“Makefile” “makefile”的文件。

● 如果找到,它会找第一个目标文件,在上面例子中,他会找code.exe这个文件,并把这个文件当做最终的目标文件。(最终目标文件必须是第一个,其他的可以乱序。)

● 如果code.exe不存在,或是code.exe所依赖的后面的code.c文件的修改时间要比code.exe文件新,那么,他就会执行后面所定义的命令来生成code.exe文件。

● 如果code.c不存在,make就会往下寻找,再检查目 

● 这就是整个make的依赖性,make会一层又一层的去找文件的依赖关系,直到最后编译出第一个目标文件。

● 在寻找过程中,如果出现错误,比如最终找不到依赖文件,那么make就会直接退出,并报错。而所定义的命令错误,或是编译不成功,make不管。make只管文件的依赖。

扩展

1. 可以使用操作符代替。

$ : 提取的意思;@:目标文件;^:依赖文件

2. 支持变量

【Linux杂货铺】自动化构建工具 Makefile_第10张图片

3. 命令前加@,可以隐藏显示

        下面是不加@符号时,要打印依赖方法。

        下面是加@符号后,不打印依赖方法。

【Linux杂货铺】自动化构建工具 Makefile_第11张图片

总结

        以上,就是本期【Linux杂货铺】的所有内容了,讲解了makefile和make的基本使用方法,及其原理。makefile就是指定的规则的文件,make就是负责解释该规则的命令。

        如果本期内容对你有所帮助,欢迎点赞,收藏,关注。Thanks♪(・ω・)ノ

【Linux杂货铺】自动化构建工具 Makefile_第12张图片

你可能感兴趣的:(Linux杂货铺,c语言,linux,笔记,学习,c++)