Makefile基础教程—写出你的第一个makefile


试想一下,如果你写出如下结构的代码,要怎么编译,请同学们思考5分钟,踊跃举手回答

哎!!!我听见最后那个同学说了,不就是这么几行代码么,a piece of cake~~~~,看我的。

挥一挥手,没带走一片云彩~~~~
     诚然,这样可以“轻松”搞定。可是如果有几十个源文件呢?几百个呢?几千个呢?该怎么办?怎么办?难道要凉拌?
所以,我们聪明的程序员们就想出了一个很好的办法,那就是makefile。
     那么,到底什么是makefile呢?makefile有什么好处呢? makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。

有了这个东东,以后我们就算有上千个源文件,修改完了之后也只需要输入一个make命令,便会自动编译连接生成目标文件。


那么,问题来了~makefile的编写究竟遵循什么规则呢?
其实也很简单啦,1、目标  2、依赖  3、规则     如下所示:
target:components 
TAB rule 
注:
    比如上例中的 
main:main.o myplus.o myminus.o 

gcc -o main main.o myplus.o myminus.o 

其中的main就是目标,main.o   myplus.o  myminus.o均为依赖),gcc -o main main.o myplus.o myminus.o 就是规则(规则这一行必须以TAB键开始哦~),就像你要建房子,
目标  就是一栋别墅,依赖 就是你的板砖、木头、玻璃等等, 规则  就是你必须先打地基,再砌墙等等。  


Makefile文件可以写成Makefile或者小写makefile,都是一样一样滴啦。Makefile还有三个非常有用的变量需要经常用到,他们分别是:$@,$^和$<.
$@--目标文件,$^--所有的依赖文件,$<--第一个依赖文件。
比如上面的makefile就可以简化成下面这样:
main:main.o myplus.o myminus.o 
gcc -o $@ $^ 

main.o:main.c myplus.h myminus.h 
gcc -c $< 

经过简化后,makefile是看起来简单了好多哈,不过我们人总是聪明的,也是懒的,总想让他更简单,所以就有了下面更一步的简化规则:
.c.o: 
gcc -c $< 
上面两行表示:所以的.o文件的依赖都是对应的.c文件,比如main.o依赖于main.c,myplus.o依赖于myplus.c,“阿猫.o”依赖于“阿猫.c”。

好了,如果上面的你已经掌握,那么恭喜你,你可以写出简单地makefile来了,可以减少更多的工作量哈,当然了,学无止境,如果要想学习更多的makefile知识,
本人强烈推荐百度一下“跟我一起写Makefile”!!!谢谢各位看客。








  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值