---- 整理自狄泰软件唐佐林老师课程
文章目录
- 1. 模块独立编译的支持
- 1.1 问题
- 1.2 背景
- 1.3 解决方案
- 1.4 关键技术点
- 2. makefile 中的代码复用
- 3. 实验
1. 模块独立编译的支持
1.1 问题
一般而言,不同工程师负责不同模块的开发,编译环境中如何支持模块的独立编译?
1.2 背景
大型项目的代码文件成千上万,完整编译的时间较长
编译模块代码时,可通过编译检查语法错误
为了提高开发效率,需要支持指定模块的独立编译
1.3 解决方案
- 将模块名作为目标名(伪目标)建立规则
- 目标对应的依赖为 build、build/module
- 规则中的命令进入对应的模块文件夹进行编译
- 编译结果存放于 build 文件夹下
1.4 关键技术点
- 如何获取 make 命令行中指定编译的模块名?
预定义变量:$(MAKECMDGOALS)
命令行中指定的目标名(make 的命令行参数)
注:第一个依赖是 build 文件夹,第二个依赖是 build 文件夹下的模块文件夹。依赖中不要使用自动变量,依赖中的 $@ 并不会被 make 解释器认为是目标的名字。
2. makefile 中的代码复用
- 当不同规则中的命令大量重复时,可考虑自定义函数
- makefile 中的自定义函数时代码复用的一种方式
- 思路:
- 将编译模块的命令集作为自定义函数的具体实现
- 函数参数为模块名,函数调用后编译参数指定的模块
- 在不同的规则中调用该函数
3. 实验
23 - 模块独立编译的支持