Makefile简单使用

Makefile

Makefile 文件定义了一系列的规则来指定哪些文件需要先编译,哪些文件需要后编
译,哪些文件需要重新编译,甚至于进行更复杂的功能操作, 可以执行操作系统的命令

规则

目标:依赖

​ 命令

  • 一般第一条核心, 下面都是为其服务提供依赖

  • 检查依赖: 执行前检查 如果不存在 向下检查其他规则 如果都找到了, 则运行

  • 检查更新: 时间更晚就重新生成目标,否则命令不会执行

变量 简化命令

自定义变量: var = hello 使用时 $(var)

预定义变量

  • $(AR) 打包静态库与.o文件
  • $(CC) gcc
app:main.c a.c b.c
gcc -c main.c a.c b.c
  • $(CXX) g++
  • $@ 目标完整名称
  • $<: 第一个依赖文件名称
  • $^ 所有依赖文件
app:main.c a.c b.c
$(CC) -c $^ -o $@
  • 通配符: 获取相同后缀文件
    • %匹配一个字符串
%.o:%.c
gcc -c $< -o $@

函数

  • $(wildcard PATTERN...)
    • 获取指定目录下指定类型的文件列表
    • Patter是字符串 即模式
    • 返回:得到的若干个文件的文件列表,文件名之间使用空格间隔
$(wildcard *.c ./sub/*.c)
返回值格式: a.c b.c c.c d.c e.c f.c
  • $(patsubst ,,)
  • 查找text中的单词 匹配patter 则用replacement替换
$(patsubst %.c, %.o, x.c bar.c)
返回值格式: x.o bar.o
#定义变量
# add.c sub.c main.c mult.c div.c
src=$(wildcard ./*.c)
objs=$(patsubst %.c, %.o, $(src))
target=app
$(target):$(objs)
	$(CC) $(objs) -o $(target)

%.o:%.c
	$(CC) -c $< -o $@

.PHONY:clean
clean:
	rm $(objs) -f

posted @ 2021-12-15 23:04  LeoSharh  阅读(67)  评论(0编辑  收藏  举报