makefile--变量的定义与使用

2018-03-11  本文已影响0人  qiuzy_666

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)

命令行执行结果如下:


image

分析:从执行结果来看,调用$(CC)相当于调用了gcc,调用$(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)

命令行执行结果如下:


image

makefile中变量的4中赋值方式(不同的赋值方式意义不同!)

简单赋值(:=)

递归赋值(=)

条件赋值(?=)

追加赋值(+=)

上一篇下一篇

猜你喜欢

热点阅读