首页 > 代码库 > linux学习之C语言(5)------ Makefile详解
linux学习之C语言(5)------ Makefile详解
对上节简单的例子,通过编写的Makefile,将原来编译时需要4条命令直接减少为一条命令就可以解决,即直接输入make即可,当然了,Makefile的好处并不指的这一点,还有很多好处,下面就对Makefile详细的进行讨论。
Makefile语法规则:
targets : prerequistes <TAB> command 或: targets: prerequistes;command <TAB> command其中,第一行是依赖关系,第二行是命令,<TAB>代表指的是一个TAB键
eg: main:main.o my_fun1.o my_fun2.o gcc -o main main.o my_fun1.o my_fun2.o</span>
表示,目标(targets)的依赖对象是main.o,my_fun1.o,my_fun2.o,当依赖的对象在目标修改后修改的话,就要去执行类似第二个行的命令。
Makefile 有三个非常有用的变量.分别是$@,$^,$<代表的意义分别是:$@--目标文件,$^--所有的依赖文件,$<--第一个依赖文件.如果我们使用上面三个变量,那么我们可以简化
上节的Makefile。
简化后的Makefile:
main:main.o my_fun1.o my_fun2.o gcc -o $@ $^ main.o:main.c my_fun1.h my_fun2.h gcc -c $< my_fun1.o:my_fun1.c my_fun1.h gcc -c $< my_fun2.o:my_fun2.c my_fun2.h gcc -c $<
还有一个Makefile的缺省规则,
..c.o: gcc -c $<这个规则表示所有的 .o 文件都是依赖与相应的.c 文件的
这样,Makefile还可以继续简化,
main:main.o my_fun1.o my_fun2.o gcc -o $@ $^ ..c.o: gcc -c $<
linux学习之C语言(5)------ Makefile详解
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。