makefile小结

<一>. 变量高级用法
a. 替换变量中的共有部分,格式: $(var:a=b) 或是 ${var:a=b}
意思是把变量var中所有以a字串结尾的a替换成b字串.
示例:
foo := a.o b.o c.o
bar := $(foo:.o=.c)
$(bar)展开的值就是a.c b.c c.c

类似的替换为“静态模式"
bar := $(foo:%.o=%.c) 展开后跟上例一个效果。

b. 变量赋值
obj = a.o b.o 一般赋值,可以引用前后面的变量
obj := a.o b.o 赋值,只可以引用前面的变量
obj ?= a.o b.o 如果之前有定义过obj,则此次赋值无效,若没有,则有效
obj += a.o b.o 变量追加值

<二>。 目标变量
<target …> :
<target …> : overide
示例:
prog : CFLAGS = -g
prog : prog.o foo.o bar.o
$(CC) ( C F L A G S ) p r o g . o f o o . o b a r . o 不 管 全 局 的 C F L A G S 是 什 么 值 , 在 p r o g 目 标 以 及 其 所 引 发 的 所 有 规 则 中 , (CFLAGS) prog.o foo.o bar.o 不管全局的CFLAGS是什么值,在prog目标以及其所引发的所有规则中, (CFLAGS)prog.ofoo.obar.oCFLAGSprog(CFLAGS)值都是-g
override是针对于系统环境传入的变量,或是make命令行指定的变量.

<三>. 模式变量
<pattern …> :
<pattern …> : override

%.o : CFLAGS = -O

<四>. 使用条件判断


else

endif
表示条件关键字,如ifeq,一共有四种
a. ifeq (, )
ifeq ‘’ ‘’
ifeq “” “”
比较参数arg1,arg2的值是否相同

b. ifneq (, )
ifneq ‘’ ‘’
ifneq “” “”

c. ifdef
变量variable-name的值非空,表达式为真,否则为假。
示例:
bar =
foo = $(bar)
ifdef foo
frob = yes
else
frob = no
endif

d. ifndef

<五>. 使用函数
$( ) 或是 ${ }

a. 字符串处理函数
$(subst ,, )
名称: 字符串替换函数–subst
功能: 把字串 中的字符串替换成
示例:
$(subst ee,EE,feet on the street)
结果:fEEt on the strEEt

$(patsubst ,, )
名称: 模式字符串替换函数–patsubst
功能: 查找 中的单词是否符合模式,匹配的话,则以替换。可以包括通配符%,表示任意长度的字串。
示例:
$(patsubst %.c,%.o,x.c.c bar.c)
返回结果:x.c.o bar.o
备注:
objects = foo.o bar.o
$(objects:.o=.c) 和 ( p a t s u b s t (patsubst %.o,%.c, (patsubst(objects)) 一样结果

$(strip )
名称: 去空格函数–strip
功能: 去掉字符串开头和结尾的空字符。
示例:
$(strip a b c ) --> “a b c”

$(findstring ,)
名称: 查找字符串函数–findstring
功能: 在字串中查找字串
示例:
$(findstring a,a b c) --> “a”
$(findstring a,b c) --> “”

$(filter <pattern…>, )
名称: 过滤函数–filter
功能: 以模式过滤 字符串中的单词,保留符合模式的单词,可以有多个模式。
示例:
sources : foo.c bar.c baz.s ugh.h
foo: $(sources)
cc ( f i l t e r (filter %.c %.s, (filter(sources)) -o foo
过滤后返回foo.c bar.c baz.s

$(filter-out <pattern…>, )
名称: 反过滤函数–filter-out
功能: 以模式过滤 字符串中的单词,去除符合模式的单词。
示例:
objects = main1.o foo.o main2.o bar.o
mains = main1.o main2.o
$(filter-out ( m a i n s ) , (mains), (mains),(objects)) --> foo.o bar.o

$(sort )
名称: 排序函数–sort
功能:给字符串中的单词排序(升序),返回排序后的字符串
示例:
$(sort foo bar lose) --> bar foo lose
sort函数会去掉中相同的单词

$(word , )
名称: 取单词函数–word
功能: 取字符串 中第个单词
示例:
$(word 2, foo bar bza) --> bar

$(wordlist ,, )
名称: 取单词串函数–wordlist
功能: 从字符串 中取从 开始到的单词串。,是一个数字
示例:
$(wordlist 2,3,foo bar gza) --> bar gza

$(words )
名称: 单词个数统计函数–words
功能: 统计 中字符串中的单词个数。
示例:
$(words, foo bar gaz) --> 3

$(firstword )
名称: 首单词函数–firstword
功能: 取字符串 中的第一个单词
示例:
$(firstword foo bar) --> foo

b. 文件名操作函数

c. foreach函数
$(foreach ,, )
var依次等于list中的变量,执行text中的表达式
示例:
names := f1 f2 f3 f4
files := ( f o r e a c h n , (foreach n, (foreachn,(names),$(n).o)
$(files) --> f1.o f2.o f3.o f4.o

d. if 函数
$(if ,) 或是 $(if ,,)

<六> 自动化变量
$@ 表示规则中的目标文件集
$< 依赖目标中的第一个目标名字
$^ 所有的依赖目标集合
$? 所有比目标新的依赖目标的集合
$+ 所有依赖目标集合,不去除重复的依赖目标

转载:https://blog.csdn.net/manshq163com/article/details/7597717

参考:
https://blog.csdn.net/TeFuirnever/article/details/107041402?utm_medium=distribute.pc_feed.none-task-blog-personrec_tag-9.nonecase&depth_1-utm_source=distribute.pc_feed.none-task-blog-personrec_tag-9.nonecase&request_id=5f0e6c8623c53c56a81f0ec0

gdb调试:
https://blog.csdn.net/TeFuirnever/article/details/107035786?utm_medium=distribute.pc_feed.none-task-blog-cf-3.nonecase&depth_1-utm_source=distribute.pc_feed.none-task-blog-cf-3.nonecase&request_id=5f087dabcccc5d5ca41bb8ae

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值