makefile--变量与函数的综合示例

2018-10-05  本文已影响0人  qiuzy_666

变量与函数的综合示例


1.项目需求


2. 关键语法


3. 关键技巧

SRCS += $(wildcard *.c)
OBJS := $(SRCS:.c=.o)
OBJS := $(addprefix path/,$(OBJS))

4. 规则中的模式替换(目录结构)

本质:匹配当前目录下的文件,然后根据模式将当前目录下的文件进行特定替换
前提:工作目录中存在func.c main.c
说明:

%.o : %.c
    gcc -o $@ -c $^

与变量的值替换的区别:
变量值替换是从给定的列表中将文件一一进行匹配,然后放入指定的依赖中;变量值替换如下所示:

OBJS := func.o main.o
$(OBJS) :  %.o : %.c
    gcc -o $@ -c $^

编译规则的依赖如下:


![10-1.PNG](https://img.haomeiwen.com/i10834716/2f45145c35635422.PNG?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

示例代码--变量与函数的综合应用
源代码如下:
const.c

const char* g_hello = "hello-makefile";

func.c

#include "stdio.h"
extern char* g_hello;

void foo()
{
    printf("void foo():%s\n".g_hello);
}   

main.c

extern void foo();

int main()
{
    foo();
    return 0;
}

makefile

CC := gcc
MKDIR := mkdir
RM := rm -rf

DIR_OBJS := objs
DIR_TARGET := target

DIRS := $(DIR_OBJS) $(DIR_TARGET)

#target/hello-makefile.out
TARGET := $(DIR_TARGET/hello-makefile.out
#SRCS = {const.c func.c main.c}
SRCS := $(wildcard *.c)
#OBJS = {const.o func.o main.o}
OBJS := $(SRCS:.c=.o)
#OBJS ={objs/const.o objs/func.o objs/main.o}
OBJS = $(addprefix $(DIR_OBJS)/,$(OBJS))

.PHONY : rebuild clean all

$(TARGET) : $(DIRS) $(OBJS)
    $(CC) -o $@ $(OBJS)
    @echo "Target file => $@"
    

$(DIRS) :
    $(MKDIR) $@
    
$(DIR_OBJS)/%.o : %.c
    ifeq ($(DEBUG),true)
    $(CC) -o $@ -g -c $^
    else
    $(CC) -o $@ -c $^
    endif
    
rebuild : clean all

all : $(TARGET)

clean :
    $(RM) $(DIRS)

10-1.PNG

执行结果如下:

10-2.PNG

下列左图为命令行执行make DEBUG:=true的结果;右图为命令行执行make的结果;可以看到,当命令行指定DEUBG值之后,进入target文件夹后命令行执行objdump -S hello-makefile.out可以看到汇编调试代码中出现了源文件中的代码,方便进行调试。而右图仅仅只有汇编部分代码。

10-3.PNG

小结:

上一篇 下一篇

猜你喜欢

热点阅读