Makefile学习笔记2:入门篇-学习点滴之Makefile基础 (zz)

 转载自 http://bluefish.blog.51cto.com/214870/163403

 
Makefile有三个非常有用的变量。分别是$@,$^,$<代表的意义分别是:
$@--目标文件,$^--所有的依赖文件,$<--第一个依赖文件。
反斜杠(/)是换行符的意思。这样比较便于Makefile的易读。
 
在定义好依赖关系后,后续的那一行定义了如何生成目标文件的操作系统命令,一定要以一个Tab键作为开头。
 
make会比较targets文件和prerequisites文件的修改日期,如果prerequisites文件的日期要比targets文件的日期要新,或者target不存在的话,那么,make就会执行后续定义的命令。
 
clean不是一个文件,它只不过是一个动作名字,有点像C语言中的lable一样,其冒号
后什么也没有,那么,make就不会自动去找文件的依赖性,也就不会自动执行其后所定义的命令。要执行其后的命令,就要在make命令后明显得指出这个lable的名字。
 
.PHONY : clean
clean :
 -rm edit $(objects)
.PHONY意思表示 clean是一个“伪目标”,。而在rm命令前面加了一个小减号的意思就是,也许某些文件出现问题,但不要管,继续做后面的事。当然,clean的规则不 要放在文件的开头,不然,这就会变成make的默认目标。不成文的规矩是——“clean从来都是放在文件的最后”。
 
如果你要在你的Makefile中使用“#”字符,可以用反斜框进行转义,如:“/#”。最后,还值得一提的是,在Makefile中的命令,必须要以[Tab]键开始。
 
默认的情况下,make命令会在当前目录下按顺序找寻文件名为“GNUmakefile”、
“makefile”、 “Makefile”的文件,找到了解释这个文件。当然,你可以使用别的文件名来书写Makefile,比 如:“Make.Linux”,“Make.Solaris”,“Make.AIX”等,如果要指定特定的Makefile,你可以使用make的“- f”和“--file”参数,如:make -f Make.Linux或make --file Make.AIX。
 
在Makefile使用include关键字可以把别的Makefile包含进来,这很像C语言的#i
nclude,被包含的文件会原模原样的放在当前文件的包含位置。include的语法是:
    include <filename>
在include前面可以有一些空字符,但是绝不能是[Tab]键开始。include和<filename>
可以用一个或多个空格隔开。
 

GNU的make工作时的执行步骤入下:(想来其它的make也是类似)
    1、读入所有的Makefile。
    2、读入被include的其它Makefile。
    3、初始化文件中的变量。
    4、推导隐晦规则,并分析所有规则。
    5、为所有的目标文件创建依赖关系链。
    6、根据依赖关系,决定哪些目标要重新生成。
    7、执行生成命令。

 

-------------------------------------

 

相关文章




  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值