美文网首页
makefile--变量与函数的综合示例

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

作者: qiuzy_666 | 来源:发表于2018-10-05 11:00 被阅读0次

变量与函数的综合示例


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://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

小结:

  • 目录可以成为目标的依赖,在规则中创建目录
  • 预定义函数是makefile实战时不可或缺的部分
  • 规则中的模式匹配可以直接针对目录中的文件
  • 可以使用命令行变量编译特殊的目标版本

相关文章

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

    变量与函数的综合示例 1.项目需求 自动生成target文件夹存放可执行文件 自动生成objs文件夹存放编译生成的...

  • go学习笔记(4) - 结构体、接口

    结构体与方法 工厂函数返回局部变量地址 结构体专有方法 结体构综合示例 接口 问题集锦 new与make new只...

  • JavaScript 代码注释规范

    文件头部注释 示例 函数方法注释 示例 变量、常量注释 示例 单行注释 多行注释

  • JavaScript-闭包的理解

    示例 闭包其实就是函数A里的函数B,可以访问函数A中的变量。 之所以函数A执行完后,函数B还能访问函数A中的变量,...

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

    makefile变量 makefile中支持程序设计语言中变量的概念 makefile中的变量只代表文本数据(字符...

  • 06. 变量

    用var语句可以定义一个变量列表。 变量类型要写在最后面。变量可以定义在函数内,也可以与函数一样定义在包内。 示例...

  • 面试题 16.01. 交换数字

    编写一个函数,不用临时变量,直接交换numbers = [a, b]中a与b的值。 示例: 输入:numbers ...

  • 【C语言学习】extern关键字的作用是什么?

    extern关键字可以用来声明变量和函数作为外部变量或者函数供其它文件使用。 extern声明变量 示例程序: t...

  • python函数变量*arg示例

    在传入可变参数时传入后参数为tuple

  • Shell 使用 unset 删除变量

    -f 选项表示删除一个已定义的函数;-v 表示删除一个变量。 删除变量示例: 在图片中的示例中,我们可以看出 un...

网友评论

      本文标题:makefile--变量与函数的综合示例

      本文链接:https://www.haomeiwen.com/subject/ymxqaftx.html