1.make是一个命令,makefile是一个文件, 依赖关系和依赖方法.
a.快速使用一下
i.创建一个Makefile文件(首字母也可以小写)
b.依赖关系和依赖方法
i.依赖关系: 我为什么要帮你? mybin:mytest.c
ii.依赖方法: 怎么帮? gcc -o mybin mytest.c
make之前要注意先创建一个mytest.c文件写好我们要运行的内容.
写入一些简单的内容主要是先跑通Makefile
iii.可以make了
这时候他自动的就能帮我们编译把源文件编译形成一个可执行程序.
c.make和makefile 修改文件内容才更新
i.基本语法
①怎么清理这个临时文件(mybin)呢?
项目的自动化构建和自动化清理
此时我们发现已经没有mybin的文件了.
②如果clear和mybin互相换位子会发生什么呢?make是clear. make mybin才是生成.
③总结:
①Makefile和make 形成目标文件的时候,默认是从上到下扫描makefile文件的, 默认形成的是第一个目标文件
②默认只形成一个
ii. make和makefile怎么知道可执行程序是比较新的呢?
这个是通过对比时间比出来的,只要可执行程序的最近修改时间比所有源文件的最近修改时间新,说明它就是最新的.
源代码和可执行程序谁比较新,如果原代码比较新就可以更新,如果可执行程序比较新就会Makefile成功
2. 认识一下时间
a. 文件 = 内容(modify)+属性(change)
b.查看这些修改等时间的指令:
state mytest.c(这里用mytest.c举例)
各个单词带表的含义:
Modify -- 内容(修改时间)
Change ---属性(改变)
Modify修改change也会跟着变,change变可能单独变
Access -(访问) : 特殊阶段更新
对比Modify最好,因为 touch mytest.c (更新文件对应的时间)
3.有没有一个方法能让我不用每次访问都touch?答案是: 有.
a.这里要介绍一下 PHONY 的使用了
i..PHONY:mybin # 修饰对应的mybin目标文件,成为一个伪目标,总是被执行.
ii.一般推荐把clean设置成伪目标.
同时为了养成良好的习惯,这里还要用一下类似于宏的操作:
至少也要这样这里用的是mytest.c举例.
$@: 代表目标文件
$^: 代表对应的依赖文件列表
到这里就结束啦, 谢谢观看!