Makefile 函数 wildcard 使用详细介绍】

请阅读【ARM GCC Makefile 编译专栏导读】

文章目录
    • [wildcard 函数介绍](#wildcard 函数介绍)
    • [Wildcard 使用背景](#Wildcard 使用背景)

wildcard 函数介绍

wildcard 函数是Makefile中的一个内建函数,用于获取符合特定模式的文件名列表。

例如,$(wildcard *.c)会获取当前目录下所有以.c为扩展名的文件列表。

一个更具体的例子:

假设我们有一个目录,其中包含多个C源文件,我们可以使用wildcard函数来获取这些源文件的列表,然后生成目标文件列表,并编写规则来编译这些源文件。

c 复制代码
SRCS := $(wildcard *.c) 
OBJS := $(SRCS:.c=.o) 

all:

$(OBJS) %.o: %.c

gcc -c \< -o @

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

在这个例子中,$(wildcard *.c)会获取所有.c文件,然后我们使用模式替换$(SRCS:.c=.o)来生成所有.o文件。

规则%.o: %.c表示每个.o文件都依赖于同名的.c文件。如果某个.c文件发生了改变,那么对应的.o文件就需要重新编译。

总的来说,wildcard函数在处理大量文件时非常有用,它可以减少手动指定每个文件的工作量。

Wildcard 使用背景

在Makefile规则中,通配符 会被自动展开。但在变量的定义函数引用时 ,通配符将失效。这种情况下如果需要通配符有效,就需要使用函数"wildcard",它的用法是:$(wildcard PATTERN...)

在 Makefile 中,它被展开为已经存在的、使用空格分开的、匹配此模式的所有文件列表。如果不存在任何符合此模式的文件,函数会忽略模式字符并返回空。

一般我们可以使用"$(wildcard *.c)"来获取工作目录下的所有的.c文件列表。复杂一些用法;可以使用

powershell 复制代码
$(patsubst %.c,%.o,$(wildcard *.c)):

 
 
 
 
 
 
  
* 1

 
  • 首先使用"wildcard"函数获取工作目录下的.c文件列表;
  • 之后将列表中所有文件名的后缀.c替换为.o

这样我们就可以得到在当前目录可生成的.o文件列表。因此在一个目录下可以使用如下内容的Makefile来将工作目录下的所有的.c文件进行编译并最后连接成为一个可执行文件:

markup 复制代码
#sample Makefile

objects := ( p a t s u b s t (patsubst %.c,%.o, (patsubst(wildcard *.c))

foo : $(objects)

cc -o foo $(objects)

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

示例

建立一个测试目录,在测试目录下建立一个名为sub的子目录

powershell 复制代码
$ mkdir test
$ cd test
$ mkdir sub

 
 
 
 
 
 
  
* 1

  
* 2

  
* 3

 

在 test下,建立 foo.cbar.c 2个文件,在sub目录下,建立sub_foo.csub_bar.c 2 个文件

建立一个简单的Makefile

PHP 复制代码
src=$(wildcard *.c ./sub/*.c)
dir=$(notdir $(src))
obj=$(patsubst %.c,%.o,$(dir) )

all:

@echo $(src)

@echo $(dir)

@echo $(obj)

@echo "end"

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

执行结果分析

第1行输出:

kotlin 复制代码
foo.c bar.c ./sub/sub_foo.c ./sub/sub_bar.c

 
 
 
 
 
 
  
* 1

 

wildcard把 指定目录 ././sub/ 下的所有后缀是c的文件全部展开。

第2行输出:

kotlin 复制代码
foo.c bar.c sub_foo.c sub_bar.c

 
 
 
 
 
 
  
* 1

 

notdir把展开的文件去除掉路径信息

第3行输出:

kotlin 复制代码
a.o b.o sa.o sb.o

 
 
 
 
 
 
  
* 1

 

$(patsubst %.c,%.o,$(dir) )中,patsubst把$(dir)中的变量符合后缀是.c的全部替换成.o,或者可以使用obj=$(dir:%.c=%.o)效果也是一样的。

相关推荐
Kusunoki_D32 分钟前
速查 Linux 常用指令 II
linux·运维·服务器
xmweisi021 小时前
Ansible内置模块之 group
linux·运维·ansible·rhce·rhca·红帽认证
小猪写代码1 小时前
Ubuntu 系统默认已安装 python,此处只需添加一个超链接即可
linux·python·ubuntu
孤寂大仙v2 小时前
【Linux笔记】——Linux线程理解与分页存储的奥秘
linux·运维·笔记
有谁看见我的剑了?2 小时前
ubuntu 22.04 wifi网卡配置地址上网
linux·运维·ubuntu
码农新猿类2 小时前
Ubuntu摄像头打开失败
linux·运维·ubuntu
jstart千语3 小时前
【消息队列】RabbitMQ基本认识
java·服务器·分布式·rabbitmq
PWRJOY3 小时前
Ubuntu磁盘空间分析:du命令及常用组合
linux·运维·ubuntu
ASDyushui3 小时前
Shell 编程之正则表达式与文本处理器
linux·正则表达式
wanhengidc3 小时前
SCDN能够运用在物联网加速当中吗?
运维·服务器·网络