在 Makefile 中,foreach 函数用于迭代处理一个以空格分隔的列表,并针对列表中的每个元素执行相同的操作。这个函数通常用于循环处理一组变量或文件名,并执行相同的规则或命令。
语法:
makefile
Copy Code
$(foreach var, list, text)
参数:
var:用于表示当前列表中的每个元素的变量。
list:以空格分隔的列表。
text:要对列表中的每个元素执行的操作或命令。
示例:
makefile
Copy Code
FILES := file1.c file2.c file3.c
OBJS := $(foreach file, $(FILES), $(file:.c=.o))
在这个例子中,$(foreach file, $(FILES), $(file:.c=.o)) 将会遍历 FILES 变量中的每个文件名,并将每个文件名的 .c 扩展名替换成 .o,最终得到 OBJS 变量的值为 “file1.o file2.o file3.o”。
另一个示例:
makefile
Copy Code
LIBS := lib1 lib2 lib3
install:$(foreach lib, $(LIBS), cp $(lib).so /usr/local/lib/$(lib).so;)
在这个例子中,$(foreach lib, $(LIBS), cp ( l i b ) . s o / u s r / l o c a l / l i b / (lib).so /usr/local/lib/ (lib).so/usr/local/lib/(lib).so;) 将会遍历 LIBS 变量中的每个库文件名,并将每个库文件复制到 /usr/local/lib/ 目录下。
总之,foreach 函数在 Makefile 中非常有用,可以帮助我们对一组变量或文件名进行迭代处理,并执行相同的规则或命令,实现灵活的循环操作。