Makefile教程:书写规则与命令详解
需积分: 49 12 浏览量
更新于2024-08-08
收藏 443KB PDF 举报
"TI公司的TMS320F28379D开发板教程,专注于讲解Makefile的书写规则"
在编程世界中,Makefile是构建自动化工具的关键,它帮助开发者有效地管理编译和链接过程。本教程以TI TMS320F28379D开发板为例,深入探讨Makefile的书写规则。规则是Makefile的核心,它定义了目标文件与其依赖文件的关系,以及如何生成或更新这些目标。
1. 规则的结构与含义:
规则通常由目标(Target)、依赖文件(Dependency)和命令(Command)组成。例如:
```makefile
foo.o : foo.c defs.h
cc -c -g foo.c
```
这条规则表明`foo.o`是目标文件,依赖于`foo.c`和`defs.h`。如果`foo.c`或`defs.h`较`foo.o`更新,或者`foo.o`不存在,那么需要重新编译`foo.c`生成`foo.o`。`cc -c -g foo.c`就是执行的命令,它告诉make如何生成目标文件。
2. 规则的顺序与终目标:
Makefile中只应有一个终目标,通常是可执行文件。其他目标是通过这个终目标间接生成的。第一条规则中的目标会被认定为终目标,如果有多个目标,第一个目标将成为终目标。make会确保这个终目标是最新的。
3. 规则的语法:
目标和依赖项之间用冒号分隔,命令前必须有Tab键作为前缀。命令可以有多行,但必须保持相同的缩进。
4. 通配符和文件搜寻:
Makefile支持通配符,如`*`匹配任意字符,`?`匹配单个任意字符。可以使用`$(wildcard)`函数来查找符合特定模式的文件。
5. 伪目标:
伪目标如`.PHONY`,用于标记那些实际上不存在的文件,避免因同名实际文件的存在而引发的误判。
6. 静态模式规则:
静态模式规则允许使用模式匹配目标和依赖,简化多文件规则的编写,如`%.o : %.c`匹配所有以`.c`结尾的文件生成对应的`.o`文件。
7. 自动推导依赖性:
make可以自动推导某些类型的依赖关系,如从`.c`文件到`.o`文件的依赖。
8. 显示命令、命令执行与错误处理:
可以使用`@`符号控制命令是否显示,`-`前缀允许命令在错误时继续执行。
9. 变量的使用:
Makefile中可以定义变量,存储重复使用的文本。变量有基础用法、嵌套、追加、覆盖等特性,还有模式变量、目标变量等特殊类型。
10. 条件判断和函数:
使用条件判断进行流程控制,如`ifdef`、`ifndef`等。函数如`$(shell)`执行系统命令,`$(patsubst)`进行字符串替换。
11. 隐含规则:
make内置了一些隐含规则,比如默认的编译和链接规则,可以利用它们简化Makefile的编写。还可以自定义模式规则和后缀规则。
12. 更新函数库文件:
对于函数库文件的管理,Makefile提供了相应的规则和函数库成员的隐含规则。
通过以上知识点,我们可以更高效地编写和维护Makefile,实现工程构建的自动化。
2018-08-01 上传
2018-09-13 上传
2023-04-24 上传
2024-12-26 上传
2024-12-26 上传
赵guo栋
- 粉丝: 43
- 资源: 3816