前文回顾:【Linux】基础开发工具(3):编译器
目录
[一 自动化工程构建----make/makefile](#一 自动化工程构建----make/makefile)
[1 背景](#1 背景)
[2 见一下怎么用](#2 见一下怎么用)
[3 理解Makefile/make,编译工作的推导过程,依赖关系和依赖方法](#3 理解Makefile/make,编译工作的推导过程,依赖关系和依赖方法)
[4 makefile最佳实践和实用语法](#4 makefile最佳实践和实用语法)
一 自动化工程构建----make/makefile
1 背景
· 会不会写 makefile,从一个侧面说明了一个人是否具备完成大型工程的能力
・一个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中,makefile 定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作
・makefile 带来的好处就是 ------"自动化编译",一旦写好,只需要一个 make 命令,整个工程完全自动编译,极大的提高了软件开发的效率。
・make 是一个命令工具,是一个解释 makefile 中指令的命令工具,一般来说,大多数的 IDE 都有这个命令,比如:Delphi 的 make,Visual C++ 的 nmake,Linux 下 GNU 的 make。可见,makefile 都成为了一种在工程方面的编译方法 。
・make 是一条命令,makefile 是一个文件,两个搭配使用,完成项目自动化构建。
make:一个命令
makefile/Makefile:文件--->描述的是如何翻译当前工程
2 见一下怎么用

3 理解Makefile/make,编译工作的推导过程,依赖关系和依赖方法
Makefile/make是依赖关系和依赖方法的集合

目标code依赖于源文件code.c,执行make命令时会自动调用gcc -o code code.c命令,将code.c编译为可执行文件code


**思考:**为什么执行code:code.c时,make后面没有跟东西,而执行clean时要写make clean?如果将上面代码的顺序换一下呢?

make/makefile:具体如何形成可执行程序的呢??推导的过程


make从上到下遇到的第一个文件,把对应的指令入栈,依次遍历,直到遍历结束,之后开始出栈,直到栈为空。当程序执行函数调用时,会将当前指令的下一条地址(返回地址)压入栈,函数执行完毕后,从栈中弹出该地址,回到原来的执行位置。
make如何知道code.c是否需要被重新编译?

清理工程

makefile使用#注释,vim用单引号注释
源文件与目标文件的 Modify 时间对比逻辑:

C 程序编译前后的文件状态对比:

4 makefile最佳实践和实用语法
malidfile最佳实践:

编译器将多个 C 源文件(如add.c、sub.c)转换为目标文件(.o文件,如add.o、sub.o),之后链接器将目标文件与库文件结合,生成可执行程序。

@(代表当前规则的 "目标",即code.exe)、^(代表当前规则的 "所有依赖",即code.o)

Makefile 变量定义:统一管理构建路径



makefile批量化处理:
做法一:


做法二:
