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 @   LeoSharh  阅读(67)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示