make--伪目标 、不同的赋值方式、变量

一.伪目标的引入

a.默认情况下
1.make认为目标对应一个文件
2.make比较目标文件和依赖文件的新旧关系,决定是否执行命令
3.make以文件处理作为第一优先级
示例

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

该示例与之前的示例加上了clean


由上面的图可以看出,在第二个我们假设在目录下存在一个clean文件(可以通过touch命令来创建),如果我们此时运行make clean,会发现make总是提示clean文件是最新的,make这种行为从原理上来说是因为它将clean当作文件来处理,由于在当前目录下找到了这个文件,加上clean目标没有任何先觉条件,所以当要求make为我们创建clean目标时它就会认为clean是最新的,从而“拒绝”进行文件的清除操作。
出现这种情形,是因为我们对于clean目标的定义与make所理解的有所出入。目标文件名与Makefile中的目标名重名在现实项目中是难免的,所以假目标的概念被提出
makefile中的伪目标
1.通过.PHONY关键字声明一个伪目标
2.伪目标不对应任何实际的文件
3.不管伪目标的依赖是否更新,命令总是执行
伪目标的语法:先声明,后使用

加入.PHONY的示例

.PHONY: clean
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

运行结果如图所示

如图所示,我们可以看出在当前目录下即使存在clean文件,有了伪目标.PHONY的使用运行make clean命令会执行删除操作

二.不同的赋值方式与变量

1.makefile中支持程序设计语言中变量的概念
2.makefile中的变量只代表文本数据(字符串)
3.makefile中的变量名规则
(变量名可以包含字符、数字、下划线;不能包含“:”,“#”,“=”或“ ”;变量名大小写敏感)
A.变量的定义和使用(通过使用变量可以使得Makefile更具有可维护性)

.PHONY: clean

CC:=gcc
TARGET:=hello.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)

运行结果如图示

可以看到在加入了变量之后,生成的结果是一样的
B.makefile中变量的赋值方式
1.简单赋值(:=)
2.递归赋值(=)
3.条件赋值(?=)
4.追加赋值(+=)
a.简单赋值(:=)
1.程序设计语言中的通用的赋值方式
2.只针对当前语句的变量有效

.PHONY: all

x=foo
y=$(x)b
x=later

xx:=foo
yy:=$(xx)b
ixx:=later

all:
    @echo "xx=$(xx),yy=$(yy)"

结果如图

b.递归赋值(=)
1.赋值操作可能影响多个其他变量
2.所有与目标变量相关的其他变量都将受到影响

.PHONY: all

foo=$(bar)
bar=$(ugh)
ugh=MYLOVE

all:
    @echo $(foo)

结果如图

c.条件赋值(?=)
1.如果变量未定义,使用赋值符号中的值定义变量
2.如果变量已经定义,则赋值无效

.PHONY: all

x:=foo
y:=$(x)b
x?=new

all:
    @echo "x=>$(x)"
    @echo "y=>$(y)"


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

.PHONY: all

x:=foo
y:=$(x)b
x+= $(y)

all:
    @echo "x=>$(x)"
    @echo "y=>$(y)"

三.预定义变量的使用

[email protected] 用于表示一个规则的目标 当一个规则中有多个目标时 [email protected]所指的是其中任一造成规则命令被运行的目标
2.$^ 表示的是规则中的所有先决条件
3.$< 表示的是规则中的第一个先决条件

运用这些规则对之前的代码进行修改


CC := g++
TARGET := hello.out

$(TARGET) : func.o main.o
    $(CC) -o [email protected] $^

func.o : func.c
    $(CC) -o [email protected] -c $^

main.o : main.c
    $(CC) -o [email protected] -c $^

.PHONY : rebuild clean all

rebuild : clean all

all : $(TARGET)

clean :
    $(RM) *.o $(TARGET)

结果如图所示

这样写的原因在之前就已经提到使得Makefile更具有可维护性

原文地址:http://blog.51cto.com/13475106/2344112

时间: 2024-07-30 23:50:55

make--伪目标 、不同的赋值方式、变量的相关文章

变量和不同的赋值方式(四)

在 makefile 中是支持程序设计语言中变量的概念的,makefile 中的变量只代表文本数据(字符串).那么在 makefile 中的变量名的规则又有哪些呢?a> 变量名可以包含字符.数字以及下划线:b> 不能包含 ":" , "#" , "=" 或 " ":c> 变量名大小写敏感.下来我们来看看变量的定义和使用,如下 下来我们以代码为例来进行分析说明 CC := gcc TARGET := hello

变量赋值方式有哪几种?

变量赋值方式一般有以下三种方式: 1)直接赋值 2)变量间赋值 3)引用赋值

PL/SQL基本结构---变量赋值方式

*****************************************   变量赋值方式 ***************************************** oracle中变量赋值方式是值拷贝而非引用         declare         v_number1 number:=100;         v_number2 number;     begin         v_number2:=v_number1;         v_number1:=200

PHP变量引用赋值与变量赋值变量的区别

变量默认总是传值赋值.那也就是说,当将一个表达式的值赋予一个变量时,整个原始表达式的值被赋值到目标变量.这意味着,例如,当一个变量的值赋予另外一个变量时,改变其中一个变量的值,将不会影响到另外一个变量.有关这种类型的赋值操作,请参阅表达式一章. <?php $foo='abc'; $b=$foo; $b="my name is $b"; echo "$b"; //my name is abc echo "$foo"; // abc PHP

Makefile伪目标

本节我们讨论一个Makefile中的一个重要的特殊目标:伪目标. 伪目标是这样一个目标:它不代表一个真正的文件名,在执行make时可以指定这个目标来执行其所在规则定义的命令,有时我们也可以将一个伪目标称为标签.使用伪目标有两点原因: 1. 避免在我们的Makefile中定义的只执行命令的的目标(此目标的目的为了执行执行一系列命令,而不需要创建这个目标)和工作目录下的实际文件出现名字冲突. 2. 提高执行make时的效率,特别是对于一个大型的工程来说,编译的效率也许你同样关心. 以下就这两个问题我

linux之Makefile 编写、规则、伪目标

什么是Makefile?首先,make是一个工具程序(Utility software),是一种控制编译或者重复编译软件的工具:make可以自动管理软件编译的内容.方式和时机从而使程序员能够把精力集中在编写代码上.那make怎样工作呢?其实make是通过makefile文件实现的.makefile是一个文本形式的数据库文件.其中包含一些规则,这些规则告诉make需要编译哪些文件.怎样编译这些文件以及在什么样的条件下去编译. 关于Makefile的基本规则: target: dependency

Mysql存储过程查询结果赋值到变量的方法

把查询结果赋值到变量,大部分情况下使用游标来完成,但是如果明确知道查询结果只有一行(例如统计记录的数量,某个字段求和等),其实可以使用set或into的方式来实现赋值.示例代码: drop table if exists test_tbl; create table test_tbl (name varchar(20), status int(2)); insert into test_tbl values('abc', 1),('edf', 2),('xyz', 3); drop proced

GNU-makefle (三) 规则语法、文件查找、伪目标

参考链接:http://blog.csdn.net/haoel/article/details/2889 当命令和依赖关系描述在同一行时,可以使用分号 分隔. 当命令太长时,也可以用反斜杠 \ 来分隔成多行,分隔出的行首有没有tab都可以(空格更无所谓了). 在指定文件目录时,可以用~来表示系统home目录,因为make会以shell来执行. VPATH Makefile文件中的特殊变量.它指定make可以去哪些目录找寻依赖文件和目标文件. 默认不定义它,则在当前目录找,多目录用冒号(:)分隔

.PHONY makefile中的伪目标

我的理解: 拿clean举例,如果make完成后,自己另外定义一个名叫clean的文件,再执行make clean时,将不会执行rm命令. 为了避免出现这个问题,需要.PHONY: clean ======================================================================================= 所谓伪目标就是这样一个目标,它不代表一个真正的文件名,在执行make时可以指定这个目标来执行其所在规则定义的命令,有时我们将一个伪