1、符号说明
$@--目标文件
$%--库文件
如:例如,如果一个目标是 foo.a(bar.o),那么, $% 就是 bar.o ,$@ 就是 foo.a 。
$^--所有的依赖文件
$<--第一个依赖文件。
$?--所有比目标新的依赖目标的集合。
2、赋值差异
= 最基本的赋值
会全部执行完成在赋值,如:
x = foo
y = $(x) bar
x = xyz
y的值将会是 xyz bar ,而不是 foo bar 。
:= 覆盖之前的赋值
x := foo
y := $(x) bar
x := xyz
y的值将会是 foo bar ,而不是 xyz bar 了。
?= 如果没有被赋值才赋值
+= 在尾部添加后面的值
.PHONY: clean```
【个人笔记】makefile
最新推荐文章于 2024-08-01 20:57:11 发布
本文详细介绍了Makefile中的特殊变量,如$@、$%、$^、$<和$?,以及它们在构建过程中的作用。同时,解释了基本赋值、覆盖赋值和条件赋值的区别,如`=`, `:=`和`?=`,并举例说明了它们的使用场景。此外,`.PHONY`目标的作用也在文中提及。
摘要由CSDN通过智能技术生成