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

变量与函数的综合示例


1.项目需求

  • 自动生成target文件夹存放可执行文件
  • 自动生成objs文件夹存放编译生成的目标文件(*.o)
  • 支持调试版本的编译选项
  • 考虑代码的扩展性

2. 关键语法

  • $(wildcard _pattern)
    获取当前工作目录中满足_pattern的文件或目录列表
  • $(addprefix _prefix,_names)
    给名字列表_names中的每一个名字增加前缀_prefix

3. 关键技巧

  • 自动获取当前目录下的源文件列表(函数调用)
SRCS += $(wildcard *.c)
  • 根据源文件列表生成目标文件列表(变量的值替换)
OBJS := $(SRCS:.c=.o)
  • 对每一个目标文件列表加上路径前缀(函数调用)
OBJS := $(addprefix path/,$(OBJS))

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

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

  • %.c用于模式匹配当前目录下的文件
  • %.o用于将%.c匹配成功的文件名进行模式替换,.c替换.o
%.o : %.c
    gcc -o $@ -c $^

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

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

编译规则的依赖如下:


![10-1.PNG](https://upload-images.jianshu.io/upload_images/10834716-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

小结:

  • 目录可以成为目标的依赖,在规则中创建目录
  • 预定义函数是makefile实战时不可或缺的部分
  • 规则中的模式匹配可以直接针对目录中的文件
  • 可以使用命令行变量编译特殊的目标版本
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,491评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,856评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,745评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,196评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,073评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,112评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,531评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,215评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,485评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,578评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,356评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,215评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,583评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,898评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,497评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,697评论 2 335

推荐阅读更多精彩内容

  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,341评论 0 5
  • 来自陈浩的一片老文,但绝对营养。 示例工程:3 个头文件*.h,和 8 个 C 文件*.c。 初 编译过程,源文件...
    周筱鲁阅读 4,652评论 0 17
  • 常言说三个女人一台戏,我们的办公室里,有十几个女性同事,一天到晚好戏不断。 办公室里有几个正在谈恋爱的小姑娘,隔三...
    黄梅枝阅读 324评论 12 14
  • 感恩我的摩托车失而复得,警察同志给力的追踪,哎呀我的小心脏也刺激了一把,这也许就是我平常保护别人财产的种子开花了吧...
    邬静阅读 105评论 0 1
  • 银河帝国正走向覆亡。 这是一个庞大的帝国,从银河每条巨大旋臂此端至彼端,其间数百万个世界,皆为帝国的势力范围。因而...
    我疯啦我膨胀啦阅读 235评论 0 0