文章目录
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}