Makefile简介
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Makefile简介相关的知识,希望对你有一定的参考价值。
参考技术A 就像dockerfile之于docker,makefile之于make.....
make命令执行时,需要一个makefile文件,以告诉make命令需要怎么样的去编译和链接程序。
你在命令行敲一个make,会自动去寻找目录下的makefile文件并执行。
可能你在C程序中见到的比较多,但是其实其他语言也是可以用到。
makefile内部是你根据makefile语法规则,自己编写的一条条shell命令等。
target
可以是一个object file(目标文件),也可以是一个执行文件,还可以是一个标签(label)。对于标签这种特性,在后续的“伪目标”章节中会有叙述。
prerequisites
生成该target所依赖的文件和/或target,没有就不需要写
command
该target要执行的命令(任意的shell命令)
下面我们看一个在 golang 中的应用例子
这里执行的任务就是本地编译,把得到的二进制可执行文件用upx压缩之后通过rsync传到服务器,
然后重启服务器的supervisor使程序重启,最后删除本地生成的可执行文件。
这一系列的任务,在makefile编写完成之后,只需要执行一句
make test
就可以完成一系列任务,非常方便。
这里需要注意的几个地方:
.PHONY
.PHONY: build clean tool lint help
其作用是声明 build / clean / tool / lint / help 为伪目标,声明为伪目标会怎么样呢?
声明为伪目标后:在执行对应的命令时,make 就不会去检查是否存在 build / clean / tool / lint / help 其对应的文件,而是每次都会运行标签对应的命令
若不声明:恰好存在对应的文件,则 make 将会认为 xx 文件已存在,没有重新构建的必要了
@
如果你执行 make 会发现,makefile中的每条命令都被打印到shell标准输出中,为什么?
因为make默认就是这么设置的,默认先打印每条命令再执行,这叫 echo
在命令前加@作用就是不让你这条命令打印到标准输出。
Makefile 简介
Makefile/makefile 简介
makefile 规则
target :prerequisites
command
target: 目标文件
prerequisites: 依赖文件
command: 执行命令
命令执行之前先检查依赖
- 依赖存在:执行命令
- 依赖不存在: 向下检测其他的规则,看看是否有一个规则是用来生成这个依赖,如果找到, 执行该规则中的命令
检测更新
- 在执行规则中的命令的时候, 会比较 目标和依赖文件时间
- 如果依赖的时间比目标的时间晚,需要重新生成目标
- 如果依赖的时间比目标的时间早, 目标不需要更新, 对应规则中的命令不需要执行
自动变量
$@: 规则中的目标
$<:规则中的第一个人依赖
$^:规则中的所有依赖
自动变量只能在规则的命令中使用
模式匹配
a.o:a.c
gcc -c a.c
b.o:b.c
gcc -c div.c
%.o:%.c
- %: 通配符, 匹配一个字符串
- 两个%匹配的是同一个字符串
以上的代码可以替换成:
%.o:%.c
gcc -c $< -o $@
一个简单的makefile
https://www.gnu.org/software/make/manual/html_node/Simple-Makefile.html
edit : main.o kbd.o command.o display.o insert.o search.o files.o utils.o
cc -o edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
main.o : main.c defs.h
cc -c main.c
kbd.o : kbd.c defs.h command.h
cc -c kbd.c
command.o : command.c defs.h command.h
cc -c command.c
display.o : display.c defs.h buffer.h
cc -c display.c
insert.o : insert.c defs.h buffer.h
cc -c insert.c
search.o : search.c defs.h buffer.h
cc -c search.c
files.o : files.c defs.h buffer.h command.h
cc -c files.c
utils.o : utils.c defs.h
cc -c utils.c
clean :
rm edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
以上是关于Makefile简介的主要内容,如果未能解决你的问题,请参考以下文章