在makefile中存在一些预定义的变量,它们大体可以分为两类,一类是自动变量,另一类是特殊变量。
data:image/s3,"s3://crabby-images/33efb/33efb4cddad71f2d03273c5095d7737e28b1293a" alt=""
自动变量的意义分别如下:
data:image/s3,"s3://crabby-images/b91fd/b91fdcc87c6c87040aedf62d5e25c61920fcf1e4" alt=""
编写如下的makefile程序对自动变量进行测试:
data:image/s3,"s3://crabby-images/0438a/0438a47a15ee529635f3c26a5dc3472ff93cba4a" alt=""
执行make命令,输出结果如下:
data:image/s3,"s3://crabby-images/bde33/bde33e5e5ff55d4c95d0e89295d97dbb674bb4e6" alt=""
小知识:
data:image/s3,"s3://crabby-images/966e7/966e7539e9cc7d2ae8da8ea20250bb3e22fe3ba4" alt=""
make中的一些特殊变量如下:
data:image/s3,"s3://crabby-images/e3d2a/e3d2a1d17cc89440a8124a7c6122f6cf9603d4bf" alt=""
编写makefile进行测试:
data:image/s3,"s3://crabby-images/fe914/fe914180968087b79281818cb5208ffa70c82cf7" alt=""
执行make all out,输出结果如下:
data:image/s3,"s3://crabby-images/2d9ab/2d9aba897039efa331ee131c6cc1ec0291af601b" alt=""
继续分析如下特殊变量:
data:image/s3,"s3://crabby-images/f3f9d/f3f9dd0f3efc80cde64d20998f94cf5d9d4f9d5f" alt=""
编写如下的makefile程序:
data:image/s3,"s3://crabby-images/e9eec/e9eec2534035de5ea6cce314be2938101623a426" alt=""
执行make,输出结果如下:
data:image/s3,"s3://crabby-images/3f506/3f506f8d9669e0060176c855c23bebacd5cc3834" alt=""
makefile中还可以执行函数的调用,例如改写makefile如下:用伪目标first、second、third来实现伪目标test的功能。
data:image/s3,"s3://crabby-images/14d74/14d7481b472f82259eac7a11b6f4dac274cdda43" alt=""
执行make test,结果如下:
data:image/s3,"s3://crabby-images/857a7/857a78f4230e2b7c9ba8fab2aa6d05a122faf170" alt=""
在实际的大型项目中,makefile程序可能由多个makefile文件构成,$(MAKE) first,$(MAKE) second,$(MAKE) third正是模拟了makefile的调用。
参考如下:
狄泰软件教程与课件
GUN make手册
专业嵌入式软件开发
<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">