news 2026/6/10 1:51:28

20251127 - Makefile通用文件详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
20251127 - Makefile通用文件详解
# --------------------------------------------------- # 1. 变量定义 # --------------------------------------------------- # 目标文件列表 objs := main.o sub.o # 依赖文件列表 (先假定名称,用于生成 wildcard 搜索列表) dep_files_list := $(patsubst %.o, .%.o.d, $(objs)) # 实际存在的依赖文件 (用于 include) # 注意:使用 new_dep_files 避免覆盖原 dep_files_list new_dep_files := $(wildcard $(dep_files_list)) # --------------------------------------------------- # 2. 默认目标 (链接) # --------------------------------------------------- test : $(objs) gcc -o test $^ # --------------------------------------------------- # 3. 模式规则 (编译与依赖生成) # --------------------------------------------------- # 修正了 -Wp,-MD 错误,使用更规范的 -MD -MF 格式 %.o : %.c gcc -c -o $@ $< -MD -MF .$@.d # --------------------------------------------------- # 4. 依赖文件包含 (核心) # --------------------------------------------------- ifneq ($(new_dep_files),) include $(new_dep_files) endif # --------------------------------------------------- # 5. 清理目标 # --------------------------------------------------- .PHONY: clean distclean clean: # 仅删除目标文件和可执行文件 rm -f test $(objs) distclean: # 删除所有编译结果和依赖文件 (更彻底的清理) rm -f test $(objs) $(actual_dep_files)

这是一个非常高质量的Makefile模板,它实现了自动依赖追踪模块化编译。下面我将逐行详细解释。

💻 Makefile 逐行详解

1. 变量定义部分

行号代码解释
1-3# ----------------...注释行,用于组织Makefile结构。
4objs := main.o sub.o定义目标文件列表。使用即时变量:=定义了最终链接所需的.o文件。
5-6# 依赖文件列表...注释行。
7dep_files_list := $(patsubst %.o, .%.o.d, $(objs))生成依赖文件名称列表。使用patsubst函数对$(objs)列表中的每一个元素进行模式替换:将所有的.o替换为.o.d,并在前面加一个点(.)。结果:dep_files_list的值为.main.o.d .sub.o.d
8-9# 实际存在的...注释行。
10new_dep_files := $(wildcard $(dep_files_list))查找已存在的依赖文件。使用wildcard函数在文件系统中搜索dep_files_list中列出的所有文件。目的:确保只include那些已经被gcc实际生成的.d文件,避免make在第一次运行时因为文件不存在而报错。

2. 默认目标(链接)

行号代码解释
13test : $(objs)目标和依赖。定义最终目标test,它依赖于变量$(objs)中的所有.o文件(即main.osub.o)。
14gcc -o test $^链接命令。使用gcc将所有依赖文件($^代表所有依赖,即main.o sub.o)链接成名为test的可执行文件。

3. 模式规则(编译与依赖生成)—核心

行号代码解释
17%.o : %.c模式规则。定义了如何从任何一个.c文件(如main.c)生成对应的.o文件(如main.o)。
18gcc -c -o $@ $< -MD -MF .$@.d编译命令。这是实现自动依赖追踪的关键命令: *gcc -c -o $@ $<:正常的编译命令。$@是目标文件(如main.o),$<是第一个依赖文件(如main.c)。 *-MD:指示 GCC在编译的同时生成依赖关系列表。 *-MF .$@.d:指示 GCC 将生成的依赖关系列表写入到指定的文件中。.$@.d展开后是.main.o.d.sub.o.d

4. 依赖文件包含(核心)

行号代码解释
22ifneq ($(new_dep_files),)条件判断。检查变量$(new_dep_files)是否不为空。只有当至少有一个.d文件存在时,才执行包含操作。
23include $(new_dep_files)包含依赖。如果.d文件存在,make会将这些.d文件的内容读入并作为Makefile的一部分来处理。这些文件包含了诸如main.o: main.c sub.h这样的规则。
24endif结束条件判断。

5. 清理目标

行号代码解释
27.PHONY: clean distclean伪目标声明。声明cleandistclean不是实际文件名,而是动作,确保它们能够可靠执行。
30clean:目标。删除编译结果(.otest可执行文件)。
31rm -f test $(objs)命令。仅删除可执行文件test和所有目标文件$(objs)
33distclean:目标。更彻底的清理。
34rm -f test $(objs) $(actual_dep_files)命令。删除所有编译结果(test.o文件)以及自动生成的依赖文件.d文件)。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 3:52:53

Open-AutoGLM核心技术揭秘:AI驱动下的公积金提取效率革命

第一章&#xff1a;Open-AutoGLM公积金提取辅助在智能化政务场景不断演进的背景下&#xff0c;Open-AutoGLM作为一款面向自动化任务处理的大语言模型辅助系统&#xff0c;为公积金提取流程提供了高效、准确的解决方案。该系统通过自然语言理解与结构化数据交互能力&#xff0c;…

作者头像 李华
网站建设 2026/6/10 10:57:19

你还在手动找加油站?Open-AutoGLM自动化查询方案全公开

第一章&#xff1a;你还在手动找加油站&#xff1f;Open-AutoGLM自动化查询方案全公开在智能出行场景中&#xff0c;频繁手动搜索加油站不仅耗时&#xff0c;还影响驾驶安全。Open-AutoGLM 是一款基于自然语言理解与地理信息融合的自动化查询框架&#xff0c;能够实时解析用户意…

作者头像 李华
网站建设 2026/6/10 11:38:54

揭秘Open-AutoGLM自动社保查询系统:如何3分钟完成百人参保数据采集

第一章&#xff1a;揭秘Open-AutoGLM自动社保查询系统的核心价值Open-AutoGLM 是一款基于大语言模型驱动的自动化社保信息查询系统&#xff0c;致力于在保障数据安全的前提下&#xff0c;提升政务信息获取的效率与准确性。该系统融合自然语言理解、自动化流程执行与多源数据对接…

作者头像 李华
网站建设 2026/6/10 6:09:42

【Open-AutoGLM实战指南】:5大场景全覆盖,轻松实现零材料提取

第一章&#xff1a;Open-AutoGLM公积金提取辅助概述Open-AutoGLM 是一款基于开源大语言模型&#xff08;LLM&#xff09;技术构建的智能辅助系统&#xff0c;专为优化公积金提取流程而设计。该系统融合自然语言理解、自动化表单填充与政策规则引擎&#xff0c;帮助用户高效完成…

作者头像 李华
网站建设 2026/6/10 10:57:21

ClickHouse 数据去重技术:大数据处理的常见问题解决方案

ClickHouse 数据去重技术:大数据处理的破局点 某电商平台技术团队发现,实时分析面板中显示的“独立访客数”(UV)总比预期高出20%,直接影响了促销活动效果评估和流量分析。深入排查时,他们惊讶地发现——问题根源竟是看似简单却深藏陷阱的数据重复问题!当你的数据仓库每天涌…

作者头像 李华
网站建设 2026/6/10 11:01:15

5个关键步骤教你部署Open-AutoGLM自动购票机器人,错过等于浪费一小时

第一章&#xff1a;Open-AutoGLM自动购票机器人概述Open-AutoGLM 是一款基于大语言模型驱动的智能自动化购票工具&#xff0c;旨在通过自然语言理解与网页交互技术&#xff0c;实现对票务平台的高效、精准操作。该系统结合了浏览器自动化框架与语义解析能力&#xff0c;能够根据…

作者头像 李华