makefile教程
Makefile 中文教程
一、什么是 Makefile?
Makefile 是一个自动化构建工具的配置文件,用于管理项目中的编译、链接、安装等任务。它通过定义依赖关系和执行命令,实现:
- 只重新编译修改过的文件
- 简化复杂的构建命令
- 实现多平台兼容构建
二、基本语法
目标: 依赖文件
[Tab]命令1
[Tab]命令2
示例:
# 编译 main.c 生成可执行文件 app
app: main.c
gcc main.c -o app
三、核心概念
-
目标 (Target)
要生成的文件名(如app)或操作名(如clean) -
依赖 (Dependencies)
生成目标所需的文件列表(如.c文件) -
命令 (Commands)
以Tab开头,执行操作的 Shell 命令
四、变量使用
# 定义变量
CC = gcc
CFLAGS = -Wall -O2
app: main.c
$(CC) $(CFLAGS) main.c -o app
五、自动变量(常用)
| 变量 | 含义 | 示例 |
|---|---|---|
$@ |
当前目标名 | app |
$< |
第一个依赖文件 | main.c |
$^ |
所有依赖文件 | main.c util.c |
示例:
app: main.c utils.c
gcc $^ -o $@
六、模式规则(通配符)
# 编译所有 .c 文件生成 .o 文件
%.o: %.c
gcc -c $< -o $@
七、伪目标
声明不生成实际文件的操作(如 clean):
.PHONY: clean
clean:
rm -f *.o app
八、函数使用
常用内置函数:
# 获取所有 .c 文件
SRCS = $(wildcard *.c)
# 将 .c 替换为 .o
OBJS = $(patsubst %.c, %.o, $(SRCS))
九、完整示例
CC = gcc
CFLAGS = -Wall
SRCS = main.c utils.c
OBJS = $(patsubst %.c, %.o, $(SRCS))
TARGET = app
$(TARGET): $(OBJS)
$(CC) $^ -o $@
%.o: %.c
$(CC) $(CFLAGS) -c $< -o $@
.PHONY: clean
clean:
rm -f $(OBJS) $(TARGET)
十、使用流程
- 编写
Makefile - 终端执行:
make # 默认构建第一个目标 make clean # 执行清理操作
十一、高级技巧
-
条件判断:
ifeq ($(OS),Windows_NT) RM = del /Q else RM = rm -f endif -
包含其他 Makefile:
include config.mk -
静默执行:
@echo "正在编译..." # @ 隐藏命令回显
十二、常见错误解决
- Missing separator:命令前缺少
Tab键 - No rule to make target:依赖文件不存在
- Command not found:命令拼写错误或未安装工具
推荐工具:
make -d查看详细调试信息
通过本教程,您已掌握 Makefile 的核心用法。实际项目中可结合自动化工具(如 CMake)生成更复杂的 Makefile。
linux系统中Makefile的使用方法
Makefile是一种编译控制文件,广泛用于项目的自动化构建。它定义了一系列的规则来指导构建的过程。通过Makefile,开发者可以轻松管理大型项目的编译链接、清理等任务。本文将从
2024-05-11 08:49:05
Makefile可以做什么?Makefile的基本格式
Makefile可以根据指定的依赖规则和文件是否有修改来执行命令。常用来编译软件源代码,只需要重新编译修改过的文件,使得编译速度大大加快。
2024-01-25 11:18:01
嵌入式中的Makefile应用
文章目录一.Makefile 引入二. Makefile语法1.通配符2.假象目标3.变量三.Makefile函数四.实例本文主要总结一下嵌入式
资料下载
张勇
2021-11-03 17:06:05
openwrt下面创建package之Makefile模版
openwrt下面创建package之Makefile模版(现代电源技术试题及答案)-进入openwrt/package/ ,mkdir eep以eep 为示例cd eepmkdir src把代码
资料下载
ah此生不换
2021-09-17 11:01:42
跟我一起学Makefile电子教材分享
什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是
资料下载
佚名
2019-12-04 15:46:21
什么是Makefile?
如果您有多个 c、c++ 和其他语言的文件,并且想通过终端命令编译它们,我们该如何编译他们呢?为了解决这类问题,Makefile就出现了。
2023-02-17 10:41:18
【Makefile】Makefile与shell命令的联系
博主最近在项目实践过程中,需要深度定制项目的Makefile,其中有些复杂的流程必须得借助shell脚本才能高效地完成,为此博主特意深入学习了在Makefile种调用shell命令的方法。
2022-07-11 09:06:07
Linux内核的Makefile、Kconfig和.config文件
Linux内核源码文件繁多,搞不清Makefile、Kconfig、.config间的关系,不了解内核编译体系,编译修改内核有问题无从下手,自己写的驱动不知道怎么编进内核,不知道怎么配置内核,这些
2020-11-12 17:31:55
换一换
- 如何分清usb-c和type-c的区别
- 中国芯片现状怎样?芯片发展分析
- vga接口接线图及vga接口定义
- 芯片的工作原理是什么?
- 华为harmonyos是什么意思,看懂鸿蒙OS系统!
- 什么是蓝牙?它的主要作用是什么?
- ssd是什么意思
- 汽车电子包含哪些领域?
- TWS蓝牙耳机是什么意思?你真的了解吗
- 什么是单片机?有什么用?
- 升压电路图汇总解析
- plc的工作原理是什么?
- 再次免费公开一肖一吗
- 充电桩一般是如何收费的?有哪些收费标准?
- ADC是什么?高精度ADC是什么意思?
- dtmb信号覆盖城市查询
- EDA是什么?有什么作用?
- 中科院研发成功2nm光刻机
- 苹果手机哪几个支持无线充电的?
- type-c四根线接法图解
- 华为芯片为什么受制于美国?
- 怎样挑选路由器?
- 元宇宙概念股龙头一览
- 锂电池和铅酸电池哪个好?
- 什么是场效应管?它的作用是什么?
- 如何进行编码器的正确接线?接线方法介绍
- 虚短与虚断的概念介绍及区别
- 晶振的作用是什么?
- 大疆无人机的价格贵吗?大约在什么价位?
- 苹果nfc功能怎么复制门禁卡
- amoled屏幕和oled区别
- 单片机和嵌入式的区别是什么
- 复位电路的原理及作用
- BLDC电机技术分析
- dsp是什么意思?有什么作用?
- 苹果无线充电器怎么使用?
- iphone13promax电池容量是多少毫安
- 芯片的组成材料有什么
- 特斯拉充电桩充电是如何收费的?收费标准是什么?
- 直流电机驱动电路及原理图
- 传感器常见类型有哪些?
- 自举电路图
- 通讯隔离作用
- 苹果笔记本macbookpro18款与19款区别
- 新斯的指纹芯片供哪些客户
- 伺服电机是如何进行工作的?它的原理是什么?
- 无人机价钱多少?为什么说无人机烧钱?
- 以太网VPN技术概述
- 手机nfc功能打开好还是关闭好
- 十大公认音质好的无线蓝牙耳机