makefile-4--变量的定义与使用

时间:2021-02-17 12:52:46

makefile变量

  • makefile中支持程序设计语言中变量的概念
  • makefile中的变量只代表文本数据(字符串)
  • makefile中的变量名规则
    –变量名可以包含字符,数字,下划线
    –不能包含“:”、“#”,“=”或“ ”
    –变量名大小写敏感

变量的定义和使用

变量的定义使用 “name := value”

CC := gcc
TARGET := hello.out

变量的使用”$(name)”

$(TARGET) : func.o main.o
$(CC) -o $(TARGET) func.o main.o

编程示例1

func.c源文件如下:

void fun()
{
printf("void fun():hello makefile \n");
}

main.c源文件如下:

extern void fun();

int main()
{
fun();

return 0;
}

makefile源文件如下:

CC := gcc
TARGET := hello.out

hello.out :main.o func.o
$(CC) -o $(TARGET) main.o func.o

main.o:main.c
$(CC) -o main.o -c main.c

func.o:func.c
$(CC) -o func.o -c func.c

.PHONY:rebuild clean all

rebuild:clean all

all:$(TARGET)

clean:
rm *.o $(TARGET)

命令行执行结果如下:
makefile-4--变量的定义与使用

分析:从执行结果来看,调用 ( C C ) g c c (TARGET)相当于调用了hello.out。代码实现了将gcc和hello.out作为变量的值,在执行的时候调用变量也就相当于调用了变量的值本身。
引用变量,有助于维护代码,当需要改变编译器和目标名称的时候,代码维护性很强,改动性很小。参看编程示例2

编程示例2

main.c func.c 文件内容均与编程实验1保持一致,修改makefile中编译器和目标文件的名称;makefile代码如下:

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

hello.out :main.o func.o
$(CC) -o $(TARGET) main.o func.o

main.o:main.c
$(CC) -o main.o -c main.c

func.o:func.c
$(CC) -o func.o -c func.c

.PHONY:rebuild clean all

rebuild:clean all

all:$(TARGET)

clean:
rm *.o $(TARGET)

命令行执行结果如下:
makefile-4--变量的定义与使用

## makefile中变量的4中赋值方式(不同的赋值方式意义不同!)
* 简单赋值(:=)
* 递归赋值(=)
–影响的变量可能会是多个
* 条件赋值(?=)
–适用于第一次定义的变量。
–如果当前要赋值的变量已经被定义过,则变量值不会被改变。
* 追加赋值(+=)
–类似于字符串的拼接

简单赋值(:=)

  • 程序设计语言中的通用的赋值方式
  • 只针对当前语句的变量有效
    makefile-4--变量的定义与使用

递归赋值(=)

  • 赋值操作可能影响多个其它变量
  • 所有与目标变量相关的其它变量都将受到影响
    makefile-4--变量的定义与使用

条件赋值(?=)

  • 如果变量未定义,使用赋值符号中的值定义变量
  • 如果变量已经定义,赋值无效
    makefile-4--变量的定义与使用

追加赋值(+=)

  • 原变量值之后加上一个新值
  • 原变量值与新值之间由空格隔开
    makefile-4--变量的定义与使用