本文主要是介绍Makefile入门实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Makefile概述
makefile文件是用来描述整个工程的编译连接规则的,主要描述哪些源文件需要编译以及如何编译,如何生成我们想要的可执行文件。一旦Makefile文件写好,只需要一个make命令,整个工程完全自动编译,极大提高了软件的开发效率。
Makefile规则
Makefile主要有三大规则:目标、依赖条件和命令
目标:是我们要生成的文件
依赖:是要生成的文件是通过哪些文件来生成的
命令:是如何将依赖中的文件生成目标文件
格式如下:
目标:依赖条件
(tab缩进)命令
Makefile简单实例
test:main.c add.c sub.c(.c文件所在路径和Makefile是同一个路径,如果不是同一个目录需要显示指定.c文件的路径)gcc main.c add.c sub.c -o test
其中test为目标,依赖条件是main.c、add.c和sub.c,命令是gcc main.c add.c -o test。
意思就是test是由main.c、add.c、sub.c文件通过gcc命令来生成的
Makefile实例进阶1
上面方式生成的test效率会比较低,因为只要任何一个依赖文件进行修改都需要重新编译所有文件。为了让只编译修改的文件,可以将上述的Makefile修改成如下形式
test:main.o add.o sub.ogcc main.o add.o sub.o -o testmain.o:main.cgcc -c main.cadd.o:add.cgcc -c add.csub.o:sub.cgcc -c sub.c
在上面的Makefile中,test、main.o、add.o、sub.o都是目标文件,在有多个目标文件的情况下,第一个目标文件为我们最终的目标文件,下面的其他所有目标文件都是用来生成第一个目标文件的
上面的实例中,test不再由.c文件来生成了,而是由.o文件来生成。当其中一个.c文件修改了,只会执行对应的命令生成.o文件,不需要所有的文件都重新编译。例如:mian.c修改了,只会执行gcc -c main.c来生成main.c文件,add.o和sub.o不需要重新编译生成。
由上面生成规则可以知道,Makefile只有检查到依赖项的生成时间比目标的时间晚,才会重新编译
Makefile实例进阶2
如果依赖文件很多,那按照上面的编写方法来写Makefile文件效率会很低,而且会写的很长。所以引入Makefile提供的变量来将上面的内容写的更加简洁一些。
obj=main.o add.o sub.o
target=test
$(target):$(obj)gcc $(obj) -o $(target)%.o:%.c
gcc -c $< -o $@
obj为自定义的变量,变量值为main.o add.o sub.o
target也是自定义的变量,变量值为test
Makefile中取变量值的方式是通过$()来取的
%.o:%.c类似于for循环,遍历target的依赖条件obj的时候,会逐个匹配的,%号是正则匹配的。例如先找到main.o时,%.o就是main.o,%.c就是mian.c,然后“gcc -c $< -o $@”就表示由main.c生成main.o.
其中 < 和 <和 <和@是Makefile中自动的变量,含义如下:
$<:表示规则中的一个依赖
$@:表示规则中的目标
$^:表示规则中的所有依赖
这篇关于Makefile入门实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!