码迷,mamicode.com
首页 > 其他好文 > 详细

5.16 下午 阅读813 单词

时间:2017-05-16 18:44:16      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:命令行   mil   文件   flags   技术分享   目标   文件的   分享   规则   

技术分享

技术分享

Makefile之执行过程

  1. 依次读取变量“MAKEFILES”定义的makefile文件列表

 

  2. 读取工作目录下的makefile文件(根据命名的查找顺序“GNUmakefile”“makefile”“Makefile”,首先找到那个就读取那个)

 

  3. 依次读取工作目录makefile文件中使用指示符“include”包含的文件

 

  4. 查找重建所有已读取的makefile文件的规则(如果存在一个目标是当前读取的某一个makefile文件,则执行此规则重建此makefile文件,完成以后从第一步开始重新执行)

 

  5. 初始化变量值并展开那些需要立即展开的变量和函数并根据预设条件确定执行分支

 

  6. 根据终极目标以及其他目标的依赖关系建立依赖关系链表

 

  7. 执行除终极目标以外的所有的目标的规则(规则中如果依赖文件中任一个文件的时间戳比目标文件新,则使用规则所定义的命令重建目标文件)

 

  8. 执行终极目标所在的规则

 

 

 

Makefile之模式规则

模式规则其实也是普通规则,但它使用了如%这样的通配符。如下面的例子:

 

%.o : %.c

 

    $(CC) -c $(CFLAGS) $(CPPFLAGS) $< -o $@

此规则描述了一个.o文件如何由对应的.c文件创建。规则的命令行中使用了自动化变量“$<”“$@”,其中自动化变量“$<”代表规则的依赖,“$@”代表规则的目标。此规则在执行时,命令行中的自动化变量将根据实际的目标和依赖文件取对应值。

 

 

 

Makefile之隐式规则       

  如果发现某变量在shellmakefile中未找不到其定义,那么恭喜你,你极大可能遇到隐式规则了。当然隐式规则中的变量只是隐式规则的一部分。

 

5.16 下午 阅读813 单词

标签:命令行   mil   文件   flags   技术分享   目标   文件的   分享   规则   

原文地址:http://www.cnblogs.com/bgd140201136/p/6862626.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!