Markfile学习笔记04|Makefile运行流程与变量
希望看到这篇文章的朋友能在评论区留下宝贵的建议来让我们共同成长,谢谢。
这里是目录
Makefile运行流程
- 若想生成目标,就要检查规则中的依赖条件是否存在。如不存在,则寻找是否有规则用来生成该依赖文件。
- 检查规则中的目标是否需要更新,必须先检查它的所有依赖,依赖中有任意一个被更新,则目标必须更新。
总结:
- 分析各个目标和依赖之间的关系。
- 根据依赖关系自底向上执行命令。
- 根据修改时间是否比目标新来确定更新。
- 如果目标不依赖任何条件,则执行对应命令,以示更新。
make和Makefile
- Makefile文件主要包含了5部分内容:
- 显式规则.说明了如何生成一个或多个目标文件。由Makefile文件的创作者指出,包括要生成的文件、文件的依赖文件、生成的命令。
- 隐式规则。由于Makefile有自动推导的功能,所以隐式的规则可以比较粗糙地简略书写Makefile文件,这是由make所支持的。
- 变量定义。在Makefile文件中要定义一系列的变量,变量一般都是字符串,这与C语言中的宏有些类似。当Makefile文件执行时,其中的变量都会扩展到相应的引用位置上。
- 文件指示。其包括什么个部分,一个是在一个Makefile文件中引用另一个Makefile文件;另一个是指根据某些情况指定Makefile文件中的有效部分;还有就是定义一个多行的命令。
- 注释。Makefile文件中只有行注释,其注释用“#”字符。如果要在Makefile文件中使用“#”字符,可以用反斜杠进行转义,如:“#”。
引入变量简化Makefile
Makefile中常见的预定义变量
命令格式 | 含义 |
---|---|
AR | 库文件维护程序的名称,默认值为ar |
AS | 汇编程序的名称,默认值为as |
CC | C编译器的名称,默认值为CC |
CPP | C预编译器的名称,默认值为$(CC)-E |
CXX | C++编译器的名称,默认值为g++ |
FC | FORTRAN编译器的名称,默认值为f77 |
RM | 文件删除程序的名称,默认值为rm-f |
ARFLAGS | 库文件维护程序的选项,无默认值 |
ASFLAGS | 汇编程序的选项,无默认值 |
CFLAGS | C编译器的选项,无默认值 |
CPPFLAGS | C预编译器的选项,无默认值 |
CXXFLAGS | C++编译器的选项,无默认值 |
FFLAGS | FORTRAN编译器的选项,无默认值 |
我们重点关注CXX、CXXFLAGS。 |
Makefile变量的使用
命令格式 | 含义 |
---|---|
$* | 不包含扩展名的目标文件名称 |
$+ | 所有的依赖文件,以空格分开,并以出现的先后排序,可能包含重复的依赖文件 |
$< | 第一个依赖文件的名称 |
$? | 所有时间戳比目标文件晚的依赖文件,并以空格分开 |
$@ | 目标文件的完整名称 |
$^ | 所有不重复的依赖文件,以空格分开 |
$% | 如果目标是归档成员,则该变量表示目标的归档成员名称 |
改写Makefile
我们修改一下之前写的Makefile。进入目录~/make/src/first_make/,修改Makefile。
# ~/make/src/first_make/Makefile
# $^ 依赖 不重复
# $@ 目标
# @ 不显示命令执行
# - 发生错误后继续向后执行
TARGET=first_make
LIBS=-lpthread
$(TARGET):first_make.cpp xdata.cpp
@#内部注释,加@防止被打印出来
@echo "begin build $(TARGET)"
@$(CXX) $^ -o $@ $(LIBS)
@echo "$(Target) build success!"
Makefile逐渐"火星文"化,真是太酷了。
都看到这里了,可以给个点赞或者评论吗?达瓦里希( ̄^ ̄)ゞ