外观
02.伪目标的引入、变量和不同的赋值方式
约 1137 字大约 4 分钟
伪目标个人随笔记录
2022-06-18
第三部分 :伪目标的引入
makefile 中的目标究竟是什么?
3.1 默认情况下
- make认为目标对应着一个文件
- make 比较目标文件和依赖文件的新旧关系,决定是否执行命令
- make 以文件处理作为第一优先级
3.2下面的代码有什么意义?

3.3 编程实验:有趣的目标 makefile.1
hello.out all : func.o main.o
gcc -o hello.out func.o main.o
func.o : func.c
gcc -o func.o -c func.c
main.o : main.c
gcc -o main.o -c main.c
clean :
rm *.o hello.out解释:当makefile同目录下,有clean文件时,就不会执行clean下的命令。因为make 以文件处理作为第一优先级。
3.4 makefile 中的伪目标
- 通过.PHONY关键字声明一个伪目标
- 伪目标不对应任何实际的文件
- 不管伪目标的依赖是否更新,命令总是执行
3.5 伪目标的语法:先声明,后使用
本质:伪目标是make中特殊目标.PHONY的依赖

3.6 编程实验:使用伪目标 makefile.2
hello.out all : func.o main.o
gcc -o hello.out func.o main.o
func.o : func.c
gcc -o func.o -c func.c
main.o : main.c
gcc -o main.o -c main.c
.PHONY : clean
clean :
rm *.o hello.out3.7 伪目标的妙用:规则调用(函数调用)
原理:当一个目标的依赖包含伪目标时,伪目标所定义的命令总是会被执行。

解释:若make rebuild,则会先执行clean下的命令,然后执行all下的命令。
3.8 技巧:绕开.PHONY 关键字定义伪目标(GNU的make才有.PHONY,若不是GNU怎么办? )
原理︰如果一个规则没有命令或者依赖,并且它的目标不是一个存在的文件名;在执行此规则时,目标总会被认为是最新的。

解释:FORCE 没有命令或者依赖,并且它的目标不是一个存在的文件名(即文件不存在),它总会被认为是最新的,所以clean下的命令,就算有clean文件存在,也一定会被执行。
3.9 编程实验:伪目标的高级应用 makefile.3 makefile.4
hello.out : func.o main.o
gcc -o hello.out func.o main.o
func.o : func.c
gcc -o func.o -c func.c
main.o : main.c
gcc -o main.o -c main.c
clean : FORCE
rm *.o hello.out
FORCE :3.10 小结
默认情况下,make 认为目标对应着一个文件
.PHONY用于声明一个伪目标,伪目标不对应实际的文件
伪目标的本质是make 中特殊目标.PHONY的依赖
使用伪目标可以模拟“函数调用”
第四部分 :变量和不同的赋值方式
4.1 makefile 中的变量
- makefile 中支持程序设计语言中变量的概念
- makefile 中的变量只代表文本数据(字符串)
- makefile 中的变量名规则
- 变量名可以包含字符,数字,下划线
- 不能包含“:”,“#”,“=”," "
- 变量名大小写敏感
4.2 变量的定义和使用

4.3 编程实验:变量定义和使用
CC := g++
TARGET := hello-world.out
$(TARGET) : func.o main.o
$(CC) -o $(TARGET) func.o main.o
func.o : func.c
$(CC) -o func.o -c func.c
main.o : main.c
$(CC) -o main.o -c main.c
.PHONY : rebuild clean all
rebuild : clean all
all : $(TARGET)
clean :
rm *.o $(TARGET)4.4 makefile中变量的赋值方式
- 简单赋值( := )
- 递归赋值( = )
- 条件赋值(?= )
- 追加赋值(+= )
不同的赋值方式意义不同!
4.5 简单赋值(∶=)
- 程序设计语言中的通用的赋值方式
- 只针对当前语句的变量有效

4.6 递归赋值( = )
- 赋值操作可能影响多个其它变量
- 所有与目标变量相关的其它变量都将受到影响

4.7 条件赋值( ?= )
- 如果变量未定义,使用赋值符号中的值定义变量
- 如果变量已经定义,赋值无效

4.8 追加赋值(+=)
原变量值之后加上一个新值
原变量值与新值之间由空格隔开

4.9 小结
- makefile中支持变量的定义和使用
- makefile中存在四种变量的赋值方式
- 简单赋值( := )
- 递归赋值( = )
- 条件赋值(?= )
- 追加赋值(+= )
