Makefile精髓

MakeFile基础详解

不想说但是该说啊,makefile虽然很多时候都不用自己写,但是要能看懂一些简单的,小破站白嫖过来的,配套了视频讲的很好,反正我是学会了哈哈哈哈哈,很精髓,这个既是笔记又是课件,水一贴吧,但是我觉得质量还是很高的,没得说

Makefile由一组规则组成,规则如下:

目标:依赖
(tab)命令
如:add.o:add.c
(一个tab缩进)gcc –Wall –g –c add.c –o add.o
目标:要生成的目标文件
依赖:目标文件由哪些文件生成
命令:通过执行该命令由依赖文件生成目标

三要素 :目标 条件 命令

基本原则:

  • 若想生成目标,检查规则中的依赖条件是否存在,如不存在,则寻找是否有规则用来
    生成该依赖文件

  • 检查规则中的目标是否需要更新,必须先检查它的所有依赖,依赖中有任一个被更
    新,则目标必须更新

  • 分析各个目标和依赖之间的关系

  • 根据依赖关系自底向上执行命令

  • 根据修改时间比目标新,确定更新

  • 如果目标不依赖任何条件,则执行对应命令,以示更新

Makefile 变量

在Makefile中使用变量有点类似于C语言中的宏定义,使用该变量相当于内容替换,
使用变量可以使Makefile易于维护,修改内容变得简单
变量定义及使用:

foo = abc
bar = $(foo)

定义了两个变量:foo、bar,其中bar的值是foo变量值的引用

1、变量定义直接用'='
2、使用变量值用$(变量名)

通常我们在Makefile中会定义一些变量,方便Makefile的修改维护

src = main.c func1.c func2.c
CC = gcc #arm-linux-gcc
CPPFLAGS : C预处理的选项 如:-I
CFLAGS:C编译器的选项 –Wall –g -c
LDFLAGS :链接器选项 –L -l

自动变量:

$@:表示规则中的目标
$<:表示规则中的第一个条件
$^:表示规则中的所有条件,组成一个列表,以空格隔开,如果这个列表中有重复的项则消除重复项。

模式规则:
至少在规则的目标定义中要包含’%‘,’%‘表示一个或多个,在依赖条件中同样可以
使用’%‘,依赖条件中的’%’的取值,取决于其目标:

模式规则示例:

%.o:%.c
$(CC) –c $(CFLAGS) $(CPPFLAGS) $< -o $@
其中,“$@”表示依次取出目标值,$<表示依次取出依赖条件。

注意:只有写成模式规则的时候,$<才表示了所有依赖条件的依次取值,否则只是取依
赖条件中的第一个

Makefile 函数

src = $(wildcard *.c)
找到当前目录下所有后缀为.c的文件,赋值给src
obj = $(patsubst %.c,%.o, $(src))
把src变量里所有后缀为.c的文件替换成.o  

clean

  • 用途:清除编译生成的中间.o文件和最终目标文件
  • make clean 如果当前目录下有同名clean文件,则不执行clean对应的命令
  • 伪目标声明:.PHONY:clean
  • clean命令中的特殊符号
  • – “-”此条命令出错,make也会继续执行后续的命令。如:“-rm main.o”
  • – “@”不显示命令本身,只显示结果。如:“@echo”clean done“”
  • 其它
  • – make 默认执行第一个出现的目标,可通过make dest指定要执行的目标
  • – distclean目标
  • – install目标
  • – make -C 指定目录 进入指定目录,调用里面的Makefile
  • – make -n:只打印要执行的命令,不会真正执行命令
  • – make -p:显示隐含规则数据库中的信息
  • – make -C:切换到另一个目录中执行该目录下的Makefile
  • – make -f:-f执行一个makefile文件名称,使用make执行指定的makefile
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值