一个简单的Makefile描述规则组成:

TARGET...:PREREQUISITES...

  COMMANDS...

  ...

target:规则的目标。通常是程序中间或者最后要生成的文件名,也可以是伪目标。

prerequisites:规则的依赖。生成规则目标所需要的文件名列表。通常一个目标依赖于一个或者多个文件。

commands:规则的命令行,每条占一行,必须以[TAB]开头。

GNUMake的执行过程:

  第一阶段:读取所有的makefile文件(包括“MAKEFILE”变量指定的,提示符“include”指定的,以及命令行选项“-f或--file”指定的makefile文件),内建所有的变量,明确规则和隐含规则,并建立所有目标和依赖关系结构链表。

  第二阶段:根据第一阶段已经建立的依赖关系结构链表决定哪些目标需要更新,并使用对应的规则来重建这些目标。

目录搜寻:自动搜索依赖文件

1.一般搜索:

  特殊变量VPATH指定依赖文件的搜索路径。用冒号或者空格隔开,当前目录永远是第一搜索目录。

  例:VPATH=src:../headers

 2.选择性搜索:

  为不同类型的文件指定不同的搜索目录,关键字为vpath。使用方法:

  1). vpath PATTERN DIR  #指定模式PATTERN的搜索目录为DIR

  2). vpath PATTERN    #清楚模式PATTERN的文件设置的搜索路径,PATTERN为空则清除所有。

  例:  vpath %.h ../headers  #%匹配一个或多个字符

变量:

1.在规则中,通配符会被自动展开。但在变量的定义和使用函数时不会。这种情况下需要通配符有效,要用到函数“wildcard”

 用法:$(wildcard PATTERN...);

 在Makefile中,它被展开成已存在的,空格分割的,匹配此模式的所有文件列表。

 如:$(patsubst %.c,%.o,$(wildcard *.c))

 将获得一个列表,为上述列表所有.c文件替换为.o文件。

2.变量取值:

 immediate=deferred  (递归展开)

 immediate?=deferred  #如果变量已经被定义过则不做任何操作

 immediate:=deferred  (直接展开)

 immediate+=deferred or immediate (变量追加,以空格分割)

 当变量使用+=时,如果此前这个变量是一个简单变量(使用:=定义的),则认为它是立即展开的,其他情况都被认为是延后展开的变量。

3.自动化变量:

$@ :代表规则中的目标文件名。

$<: 规则的第一个依赖文件名。

$^: 规则的所有依赖文件列表,空格分割。

$?: 所有比目标文件更新的依赖文件列表。

$(@D):目标文件的目录部分(不含最后一个反斜线\)。

$(@F):目标文件的实际文件名。

$*: 在模式规则和静态模式规则中,代表“茎”,即%所代表的部分(若干文件名中存在目录,茎也将其包括)。

  

静态模式规则:

  存在多个目标,并且不同目标可以根据目标文件的名字来自动构造出依赖文件。要求依赖文件类似。

语法:

TARGETS..:TARGET-PATTERN:PREREQ-PATTERNS..

  COMMANDS

  ...

其中TARGETS为一系列目标文件。

TARGET-PATTERN为目标模式。

PREREQ-PATTERNS为依赖模式。

  从目标模式的目标名字中抽取一部分字符串(茎),并使用茎替代依赖模式中相应部分来产生对应目标的依赖文件。常用模式字符为%。

在使用静态模式规则时,指定目标必须和目标模式相匹配,否则会出错。

例:

objects=foo.o bar.o

$(objects):%.o:%.c

  $(cc) -c $< -o $@

 

命令:

·多行命令由多个独立的shell去执行。

·较长行可用反斜线\分解为多行。

·规则中命令在运行结束后,make会检测命令执行的返回状态,如果返回成功,则往下执行;如果出错,则会放弃对当前规则的执行。在命令前加-可以忽略错误。

·命令的执行默认回显,在命令前加@则不回显。

·默认情况下,make执行Makefile中第一个规则(终极目标)。

函数:

  函数的调用方法为:

  $(Function Argv) 或 ${Function Argv} ,当有多个参数时,用逗号隔开。

常用文本处理函数:

·模式替换

  $(patsubst PATTERN,REP,TEXT)

  将TEXT中以空格分开的单词列表,符合模式PATTERN的替换为REP,可用%代表一个单词中的若干字符。返回新的列表。

·字符串操作

  $(strip STRING)

    去掉STRING中开头和结尾的空格。

  $(filter PATTERN...,TEXT)

    过滤掉字符列表中所有不符合模式的单词,多个模式用逗号分隔。$(filter-out ...)与之相反。

·文件名处理

  $(dir NAMES...)  取目录

  $(notdir NAMES...) 取文件名 

  $(suffix NAMES...) 取后缀

  $(addsuffix SUFFIX,NAMES) 加后缀

  $(wildcard PATTERN) 列出当前目录下所有符合模式的文件名。

隐含规则:

  依赖于make中的后缀列表.SUFFIXES(一个特殊目标)。

.SUFFIXES:  #删除所有已定义的可识别后缀

.SUFFIXES:.c .o   #重新定义

Makefile笔记的更多相关文章

  1. Makefile笔记之二------make的递归执行

    1.make的递归过程指的是: 在Makefile中使用"make"作为一个命令来执行本身或者其它makefile文件的过程. 2.递归的意义: 当前目录下存在一个"su ...

  2. Makefile笔记之一 ------ 变量的引用及赋值

    1.变量的引用方式: "$(变量名)"或者"¥{变量名}" 例如: ${Objs}就是取变量Objs的值 注意: 当变量名为单字符是可以采用:"$a& ...

  3. makefile 笔记

    1.Makefile中命令前的@和-符号 如果make执行的命令前面加了@字符,则不显示命令本身而只显示它的结果; Android中会定义某个变量等于@,例如 hide:= @ 通常make执行的命令 ...

  4. 数码相框之Makefile笔记

    本程序的Makefile分为3类:1. 顶层目录的Makefile2. 顶层目录的Makefile.build3. 各级子目录的Makefile 一.各级子目录的Makefile: 它最简单,形式如下 ...

  5. [转]Windows平台下Makefile学习笔记

    Windows平台下Makefile学习笔记(一) 作者:朱金灿 来源:http://blog.csdn.net/clever101 决心学习Makefile,一方面是为了解决编译开源代码时需要跨编译 ...

  6. Makefile的学习笔记

    Makefile的学习笔记 标签: makefilewildcard扩展includeshellfile 2012-01-03 00:07 9586人阅读 评论(2) 收藏 举报  分类: Linux ...

  7. Linux 编程学习笔记----动笔makefile档

    Befroe Beginning. 在设置暑假的plan ,关于Linux的书籍如今在看的是ALP和Linux高级程序设计(杨宗德)第三版.在计划中的是Linux高级环境编程. 如今開始关于Linux ...

  8. makefile 学习笔记

    1/ 编写简单makefile test_out: test.o g++ test.o -o test_out test.o: test.cpp test.h g++ -c test.cpp test ...

  9. [转]Linux学习笔记——例说makefile 头文件查找路径

    0.前言     从学习C语言开始就慢慢开始接触makefile,查阅了很多的makefile的资料但总感觉没有真正掌握makefile,如果自己动手写一个makefile总觉得非常吃力.所以特意借助 ...

随机推荐

  1. WINDOW的cmd的命令【转载】

    转载地址:https://zhidao.baidu.com/question/583956458.htmlwinver---------检查windows版本 wmimgmt.msc----打开win ...

  2. ext 自带搜索功能

  3. ASIHTTPRequest详解 [经典3]

    大文件断点续传 0.94 以后支持大文件的断点下载,只需要设置: [ request setAllowResumeForFileDownloads:YES ]; [ request setDownlo ...

  4. (五)WebRTC手记Channel概念

    转自:http://www.cnblogs.com/fangkm/p/4401075.html 前面两篇博文完整地介绍了WebRTC音视频的采集模块,接下来应该开始介绍关键的音视频编码模块.不过在介绍 ...

  5. Linux :Can&#39;t start up: not enough memory

    http://stackoverflow.com/questions/9634577/linux-cant-start-up-not-enough-memory

  6. poj 1797(最短路变形)

    题目链接:http://poj.org/problem?id=1797 思路:题目意思很简单,n个顶点,m条路,每条路上都有最大载重限制,问1->n最大载重量.其实就是一最短路的变形,定义wei ...

  7. GridBagLayout:网格包布局管理器

    GridBagLayout:网格包布局管理器   GridBagLayout可以说是布局管理器Layout中最复杂的一个,其中涉及到的参数也比较得多,比如说: GridBagConstraints g ...

  8. 分享PHP中的10个实用函数

    分享PHP中的10个实用函数 PHP的功能越来越强大,里面有着非常丰富的内置函数.资深的PHP程序员对它们可能都很熟悉,但很多参加PHP培训的PHP初学者,仍然对一些非常有用的函数不太熟悉.这篇文章里 ...

  9. 【Learning】 多项式的相关计算

    约定的记号 对于一个多项式\(A(x)\),若其最高次系数不为零的项是\(x^k\),则该多项式的次数为\(k\). 记为\(deg(A)=k\). 对于\(x\in(k,+ \infty)\),称\ ...

  10. android:layout_gravity和gravity的区别

    文章转自http://blog.csdn.net/shakespeare001/article/details/784346,给出了很详细的解释. 1.首先来看看Android:layout_grav ...