项目构建工具:make/Makefile

Makefile

  • 是一个普通的文本文件,文件中记录的是一个项目的所有构建规则

make

  • 是一个解释程序,在执行 make 命令的时候,会到当前目录里下寻找 Makefile 文件,然后对 Makefile 中记录的构建规则进行逐行解释执行,最终完成整个项目的构建。

Makefile 编写规则

  • 目标对象:依赖对象
  • [Tab]为了生成目标对象所执行的命令语句
    项目构建工具:make/Makefile
预定义变量
  • $^ : 所有的依赖对象内容
  • [email protected]:目标对象内容
  • $<:依赖对象中的第一个
    项目构建工具:make/Makefile
关键字 wildcard
  • 当一个项目中有多个依赖对象(依赖对象为 .c 文件)时,为了解决在 Makefile 编写时,减少书写依赖对象的麻烦,于是就有了 wildcard 关键字。
    项目构建工具:make/Makefile
关键字 patsubst
  • 当一个项目中有多个依赖对象(依赖对象为 .o 文件)时,为了解决在 Makefile 编写时,减少书写依赖对象的麻烦,于是就有了 wildcard 关键字。
    项目构建工具:make/Makefile
    为了减少代码量,我们还可以用上通配符:
    项目构建工具:make/Makefile
项目文件清理与申明伪对象
  • 现在Makefile 里面的代码如下:
    项目构建工具:make/Makefile

  • 工程是需要被清理的 ,在我们 make 之后会有一大堆的 .o 文件,这些东西是需要被清理的。但是,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行,不过,我们可以显示的 make 执行。
    项目构建工具:make/Makefile
    存在一个问题是,如果当前目录下有 clear 文件,这时候显示执行 make clear 时,会t提示说{make: “clear”是最新的.}。
    项目构建工具:make/Makefile
    为了解决这个问题,一般我们这种 clear 的目标文件,我们将它设置为伪目标,用 .PHONY 修饰。伪对象的特征是:不管目标对象是否为最新,每次都要重新生成。
    项目构建工具:make/Makefile

make 的解释执行规则

  • 从上往下找到第一个目标对象,生成后,则退出。make会一层又一层地去找文件的依赖关系,直到终编译出第一个目标文件。在找寻的过程中,如果出现错误,比如后被依赖的文件找不到,那么make就会直接退出。
    项目构建工具:make/Makefile