默认的情况下,make命令会在当前目录下按顺序找寻文件名为"GNUmakefile"、"makefile"、"Makefile"的文件,找到了解释这个文件。
在这三个文件名中,最好使用"Makefile"这个文件名,因为,这个文件名第一个字符为大写,这样有一种显目的感觉。最好不要用"GNUmakefile",这个文件是GNU的make识别的。
target : dependents_1 dependents_2 ... dependents_n
command_1
command_2
command_3
(1)makefile中的变量赋值方式
makefile中定义的变量, 赋值中还有其他引用变量,makefile会将变量逐级展开
赋值操作符前后可以有若干空格
1> 操作符 =
递归展开引用变量, 直到找到被引用的变量的 最新值(搜索makefile)
var = I love
variable = linux
var += $(variable)
variable = magic
all:
@echo $(var)
输出:
I love magic
2> 操作符 :=
递归展开引用变量, 只找到该变量赋值 之前 , 最新的引用变量的值 (不搜索整个makefile)
m := mm
x := $(m)
y := $(x) bar
x := later
all:
@echo $(x) $(y)
输出:
$x ---> later
$y ---> mm bar
(若将 y:= 改成 y= ,$y值为:later bar)
3>操作符 +=
可以通过+=为已定义的变量添加新的值
当变量从前没有被定义过, +=和=是一样的,它定义一个递归展开的变量,但是,当变量已经有定义的时候,+=只是简单的进行字符的添加工作。
如果起初你用:=定义变量,那么+=只是利用变量的当前值进行添加
如果起初用=定义变量,+=的行为就变得有些古怪,它并不会在使用+=的地方马上进行变量展开,而是会把展开工作推后,直到它找到最后变量的定义,这和=定义变量的行为是类似的
4>操作符 ?= (不奏效)
赋默认值,如果没有初始化该变量,就给它赋上默认值。如:
ARCH=arm
ARCH ?= i386
all:
@echo $(ARCH)
输出:
arm
ARCH=
ARCH ?= i386
all:
@echo $(ARCH)
输出:
i386
(2)makefile主要预定变量
$*不包括扩展名的目标文件名称
所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件
%HTML_CONTENT%lt;第一个依赖文件的名称
$?所有的依赖文件,以空格分开,这些依赖文件的修改日期比目标的创建日期晚
$@目标的完整名称
$^所有的依赖文件,以空格分开,不包含重复的依赖文件
$%如果目标是归档成员,则该变量表示目标的归档成员名称
(3)makefile中内定函数使用
1> wildcard
2> patsubst
3> notdir
SUB_DIR=./ locate order_maker scheduler transmit
INCLUDE = $(foreach temp,$(SUB_DIR), -I./$(temp))
SRC = $(foreach temp,$(SUB_DIR), $(wildcard $(temp)/*.cpp))
OBJS = $(foreach temp,$(SRC), $(patsubst %.cpp,%.o,$(temp)))
OBJS_LINK = $(foreach temp,$(OBJS), obj/$(patsubst %.cpp,%.o,$(notdir $(temp))))
(4)makefile中的文件搜索路径
在makefile中,可以通过给 VPATH 赋值来设置规则中目标文件和依赖文件的搜索目录。
Make首先搜索当前目录,如果未找到依赖的文件,make将按照VPATH中给的目录依次搜索VPATH对makefile中所有文件都有效。
如:
VPATH:=/c/ming \
/c/ming/head
也可以使用指令 vpath ,与VPATH在使用上的区别是:vpath可以给不同类文件指定不同的搜索目录。
如:
vpath %.c /c/ming
vpath %.h /c/ming/head
vpath %.c 表示清除所有vpath对%.c设置的搜索目录
本文出自 “清风徐来” 博客,请务必保留此出处http://cui918.blog.51cto.com/5884562/1877398
原文:http://cui918.blog.51cto.com/5884562/1877398