makefile学习笔记-makefile介绍(makefile是如何工作的)

本文介绍了Makefile的工作流程,包括如何查找、解析依赖关系并执行编译命令。详细解释了目标文件、依赖项及规则,帮助理解Makefile在项目构建中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

20180411 makefile学习笔记-makefile介绍(makefile是如何工作的


在默认的方式下,也就是我们只输入make命令那么:


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


2、若找到,他会找文件中的第一个目标文件(target),在“makefile介绍(makefile的规则)”文章中,他会找到“edit”这个文件,并把这个文件作为最终的目标文件。
3、若edit文件不存在,或是edit所依赖的后面的.o文件的文件修改时间比edit这个文件新,那么,它就会执行后面所定义的命令来生成edit这个文件。
4、若edit所依赖的.o文件也存在,那么make会在当前文件中找目标为.o文件的依赖性,若找到则再根据那一个规则生成.o文件。(这有点像堆栈的过程)
5、当然,你的C文件和H文件是存在的了,于是make会生成.o文件,然后再用.o文件执行make,也就是生成执行文件edit了。


这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。在找寻的过程中,若出现错误,,比如最后被依赖的文件找不到,那么make就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make根本不理,,make只管文件的依赖性,即,若在找了依赖关系之后,冒号后面的文件还是不在,那么对不起,他就不工作了。




通过上面的分析,我们知道,像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示要make执行,即输入命令: make clean ,以此来清除所有的目标文件,以便重新编译。






于是在我们编程中,若这个工程已经被编译过了,当我们修改了其中一个源文件,比如file.c,那么根据我们的依赖性,我们的目标file.o会被重新编译,(也就是在这个依赖性关系后面所定义的命令),于是file.o的文件也是最新的了,于是file.o的文件修改时间要比edit更新,所以edit也会被重新链接了(详见edit目标文件后定义的命令)。


而如果我们改变了“command.h”,那么 kbd.o、command.o、files.o都会被重新编译,并且,edit也会被重新链接。
































































































评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值