今天学习Makefile预定义变量的使用,加qq:1126137994.微信:liu1126137994一起学习更多技术!!!
1.预定义变量:自动变量
在Makefile中存在一些预定义过的变量,我们可以直接拿来使用而不用自己再定义
- 自动变量
$@ , $^ , $<
- 特殊变量
$(MAKE) , $(MAKECMDGOALS) , $(MAKEFILE_LIST) , $(MAKE_VERSION) , $(CURDIR) , $(.VARIABLES) ...
我们先来看看特殊变量的意义:
-$@
*代表当前规则中,触发命令后,会被执行的目标
-$^
*代表当前规则中的所有的依赖
-$<
*代表当前规则中的第一个依赖
自动变量的使用示例如下所示:
all : first second third
@echo "\$$@ => $@"
@echo "$$^ => $^"
@echo "$$< => $<"
注意:
1. "$"对于Makefile来讲具有特殊含义,所以输出时,要加一个"$"进行转义
2. "$@"队友Bash shell 具有特殊意义,所以输出时需要加上"\"进行转义
下面给出一个例子来理解上述的概念:
.PHONY : all first second third
all : first second third
@echo "\$$@ => $@"
@echo "$$^ => $^"
@echo "$$< => $<"
firtst:
second:
third:
输入make运行后,显示:
下面我们将第四课的Makefile修改一下,使用自动变量让内容更简洁(点击查看第四课的博客:第四课内容)
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)
将上述Makefile修改为以下的内容:
CC := g++
TARGET := hello-world.out
$(TARGET) : func.o main.o
$(CC) -o $@ $^
func.o : func.c
$(CC) -o $@ -c $^
main.o : main.c
$(CC) -o $@ -c $^
.PHONY : rebuild clean all
rebuild : clean all
all : $(TARGET)
clean :
$(RM) *.o $(TARGET)
可以看出,使用自动变量后,Makefile的内容变得更简洁!!!
2.预定义变量:特殊变量
一些特殊变量的意义:
- $(MAKE) 当前make解释器的文件名
- $(MAKECMDGOALS) 命令行中指定的目标名(make的命令行参数)
- $(MAKEFILE_LIST) make所需要处理的makefile文件列表,当前makefile的文件名总是处于列表最后,文件名之间以空格分离
看下面的例子来更加深刻的理解上述三个变量的意义:
.PHONY : all out first second third test
all out :
@echo "$(MAKE)"
@echo "$(MAKECMDGOALS)"
@echo "$(MAKEFILE_LIST)"
first :
@echo "first"
second :
@echo "second"
third :
@echo "third"
test :
@$(MAKE) first
@$(MAKE) second
@$(MAKE) third
输入:make test:
输入:make all :
输入:make first :
一些特殊变量的意义:
- $(MAKE_VERSION) 代表当前make解释器的版本
- $(CURDIR) 代表当前make解释器的工作目录
- $(.VARIABLES) 所有已经定义了的变量名列表(预定义和自定义的变量都包括在内)
看下面一个例子来理解一下上面三个特殊变量的意义与使用方法:
.PHONY : test1 test2
TDelphi := Delphi Tang
D.T.Software := D.T.
test1 :
@echo "$(MAKE_VERSION)"
@echo "$(CURDIR)"
@echo "$(.VARIABLES)"
test2 :
@echo "$(RM)"
输入make运行结果为:
从上面运行结果可以看出我的make的版本是:3.81 make解释器的目录为:/home/delphi 而且可以在变量名列表中找到我们定义的变量D.T.Software 与 TDelphi
3.总结
- makefile中提供了预定义变量供开发者使用
- 预定义变量的使用能够使开发变得更加高效
- 自动变量是makefile中最常见的变量
- 使用$(.VARIABLES)能够获取所有的特殊变量
想一起探讨以及获得各种学习资源加我:
qq:1126137994
微信:liu1126137994
可以共同交流关于嵌入式,操作系统,C++语言,C语言,数据结构等技术问题。