Make他作为一个构建工具,有很多的黑科技在里面,如果要细细的剖析他,那应该可以出一本书了。
这篇文章我只给大家由浅入深的介绍几个常用的技能点,满足日常开发使用即可,想更加深入就得你自己根据业务需要去学习了。
01
基础
我们在写Makefile文件时,需要明白他的一个理论,我个人理解,Makefile其实他就是把一些程序构建流程给自动化了。
我们在构建项目时,至少会根据生产和测试两种不同环境做不同的构建方案。 有时呢,我们在构架项目时还得一步一步构建,不能一个命令搞定,需要分多步,所以 make 采用了target 这个构建理念。
target这个理念你可以理解是,我们平时在写代码时,里面类的方法,每个方法里面做不同的构建工作,通过 make target 命令去指挥。
大体的一个框架结构如下:
target : prerequisites ...
command
...
...
prerequisites 就是,要生成那个target所需要的依赖,他会先执行这些依赖,然后再执行这个target下面的命令。
command 也就是make需要执行的命令,可以是任意的shell命令。
这里写个最简单的hello,功能很简单就在控制台输入一句“hello”,如下图所示:
这里的 echo "hello" ;
这是shell脚本的语法,在控制台打印字符串,不熟悉的可以去看下 shell 的相关知识点。
可能你发现了,按照我们的逻辑,控制台应该只显示hello
才对,但图片中,在这个结果之前还把相关的 shell 命令给输出了,如果我们不想看到shell命令,在前面加 @
符号就可以了,像这样:
一下就干净了。
02
声明变量
Makefile也支持声明变量的,像这样:
我们在第二行声明了一个NAME
变量,后面通过${NAME}
花括号这种语法取得了这个变量。
你如果这样写$(NAME)
用圆括号,也是可以取到的,同时如果你一行只执行一条命令的话,后面是可以不需要加分号的,像这样。
03
target和本地文件名或者文件夹冲突
有时我们的target下的指令,需要创建一个和target同名的文件或者文件夹,如下图所示:
这时执行这个target就会报错,当然一般情况下可能不会出现这问题。
要解决这个问题,只需要在我们的go
这个target上面加上一个
.PHONY: create
再执行下,就如下图所示了:
.PHONY是一个伪目标,可以防止在Makefile中定义的只执行命令的目标和工作目录下的实际文件出现名字冲突,另一种是提交执行makefile时的效率。
所以在很多开源的Makefile里面常常会看到它的身影。
04
target依赖
有时我们在执行这个 target 之前需要先执行一步构建,这个 Makefile为你想到了,只需要在我们的 target的冒号后面加上需要的依赖模块就好,像这样:
05
判断
在构建项目时,偶尔也会用到对某个变量进行判断,Makefile里面的判断是这样玩的:
这里在 build
这个target里面,我们首先做了一个判断,看条件是否允许,允许了我再编译。
好了,看到这里就结束了。
你现在再去用Make这个工具去构建你的项目基本就没什么问题了,同样你再去看开源项目的Makefile,如果不是很奇葩的,你基本能看懂了。
来,给你看一个最近很火的区块链项目fabric(超级账本),他的Go SDK里面的Makefile片段,是不是都能看懂了。