在Makefile规则中,会对通配符进行展开,但是在变量的定义和函数的引用的时候通配符就会失效,这种情况下若是想让通配符有效,就需要使用函数"wildcard",使用方法是:$(wildcard PATTERN…) 。在Makefile中,它被展开为已经存在的、使用空格分开的、匹配此模式的所有文件列表。如果不存在任何符合此模式的文件,函数会忽略模式字符并返回空。
一般我们可以使用“$(wildcard *.c)”来获取工作目录下的所有的.c文件列表。
下面这句的作用就是将当前文件文件夹下的所有的.c文件列表换成.o文件列表,并将其赋值给objects
#sample Makefile
objects := $(patsubst %.c,%.o,$(wildcard *.c))
使用上诉指令生成的.o文件,最终生成ser可执行文件
ser : $(objects)
cc -o ser $(objects)
这里我们使用了make的隐含规则来编译.c的源文件。对变量的赋值也用到了一个特殊的符号(:=)。
1、wildcard : 扩展通配符
2、notdir : 去除路径
3、patsubst :替换通配符
本文深入讲解Makefile中通配符的正确使用方法,通过wildcard函数实现文件名的动态匹配,结合实例演示如何生成目标文件列表及使用隐含规则进行编译。
1346

被折叠的 条评论
为什么被折叠?



