嵌入式开发Day06-07(2024.03.20-21)

makefile学习记录(2024.03.20-21)

makefile

简介

makefile文件主要用于在没有集成开发环境时,对工程文件进行自动化编译工具
makefile本质是一个文件,需要配合make命令进行自动化编译。文件名常首字母大写
make是一个命令工具,用来解释makefile文件中的代码,从而实现自动化编译。编译使用的编译器本质上还是gcc
makefile文件中定义了一系列规则来指定,那些文件需要先编译,那些文件需要后编译,那些文件需要重新编译,甚至于进行一些更复杂的操作。

cmake:(补充)

安装

apt-get install make

规则

makefile 规则三要素
1、目标:要生成的目标文件
2、依赖:目标文件由那些文件生成
3、命令:通过执行该命令由依赖文件生成目标
格式:目标:依赖
<tab> 命令 //注意命令需要以tab键开始
当依赖不存在时,会寻找新规则,用来生成依赖条件
所有依赖都存在,会检查规则中的目标是否需要更新,即依赖被更新目标文件也会更新

makefile中的变量

makefile中使用变量有点类似于C语言中的宏定义,使用该变量相当于内容替换,使用变量可以使makefile易于维护,修改变得简单
普通变量:用户自定义 OBJ_A=A OBJ_B=$(OBJ_A),使用的是最终赋的值
‘ := 表示直接赋值
‘ ?= 默认值,该变量不赋值时使用默认值
自动变量:
$@: 若规则中有多个目标,匹配模式中定义的目标集合
$<:依赖文件集合的第一个文件
$^:去除重复的依赖文件

all:main.o fun.o
	gcc main.o fun.o -o all
$@ ==>all
$< ==>main.o
$^ ==>main.o fun.o
makefile 伪目标

当makefile文件的目录下有和makefile文件中的目标同名的文件存在时,执行make时会报错,伪目标就是为了解决这种错误的

.PHONY : clean
clean : 
	rm *.o ......

如果makefile文件目录下也存在clean文件,make时会报错,添加.PHONY : clean ,就可以解决这个问题

makefile中的函数库

wildcard
功能:通配符
使用:SRC = $(wildcard ./*.c) ==>匹配所有c文件赋值给SRC

patsubst
功能:替换文件后缀 $(patsubst 原模式 ,目标模式,文件列表 )
使用:OBJ = $(patsubst %.c,%.o,$(SRC)) ==>取出SRC中的所有值,然后将.c文件替换为.o 最后赋值给OBJ变量

指定头文件路径
linux中一般用 -I (i)来指定头文件路径

mapp:*.c
	gcc -I path -o mapp

指定库文件路径
linux中一般用 -L 来指定库文件路径

LDFLAGS = -L /user/lib

链接具体的库
linux中一般用 -l 库名(小写L) 来指定具体库

LIBS = -lname   //-l后直接写库名,没有空格
调用子makefile的方法

在主makefile文件中写入内容,调用子makefile
make -C 子makefile文件路径

makefile 调用shell命令的方法

${ shell command}
获取当前路径 PATH = ${ shell pwd}

makefile静态模式
  • 22
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值