Makefile教程

avatar
作者
筋斗云
阅读量:0
  • 安装makefile

  • makefile基础

  • C语言编译makefile

一、安装makefile

在ubuntu22.04版本上,打开终端,输入命令行:

$ sudo apt install build-essential 

安装完成后,查看makefile版本,看是否安装成功

make -v

二、makefile基础

在 Linux(unix )环境下使用GNU 的make工具能够比较容易的构建一个属于你自己的工程,整个工程的编译只需要一个命令就可以完成编译、连接以至于最后的执行。

当我们在终端输入make命令时,它就在当前目录搜索makefile文件,根据这个文件的命令规则,自动化的执行命令。比如有三个文件a.txt、b.txt、c.txt。现在需要合并a与b文件生成新文件m.txt,再将m.txt与c.txt文件合并生成最终文件out.txt。以该逻辑我们编写一个makefile文件。

makefile编写规则

要编写makefile文件,首先要清楚它的命令规则。Makefile由若干条规则(Rule)构成,每一条规则指出一个目标文件(Target),若干依赖文件(prerequisites),以及生成目标文件的命令。

比如a.txt与b.txt合并生成m.txt

依赖文件则是a.txt、b.txt,而目标文件则是m.txt

因此该生成规则如下:

# 目标文件: 依赖文件1 依赖文件2 m.txt: a.txt b.txt 	cat a.txt b.txt > m.txt

由此可见,makefile命令规则格式即是:目标文件: 若干依赖文件,紧接着以Tab开头的为命令用来生成目标文件。

依据这一规则,我们可以为上述例子构建makefile。

out.txt: m.txt c.txt     cat m.txt c.txt > out.txt  m.txt: a.txt b.txt     cat a.txt b.txt > m.txt

make默认执行第一条规则。上述规则首先会运行第一规则,但是由于第一规则发现找不到依赖文件m.txt,于是向下运行查找m.txt的运行规则。执行完m.txt规则创建出m.txt后,再执行out.txt这一规则。

makefile会执行打印出每一条命令,便于我们观察调试。如果我们再次运行make。

 make使用文件的创建和修改时间来判断是否应该更新一个目标文件。

我们发现终端会提示我们当前文件已是最新。make通过检测output.txt的创建时间在它的依赖文件x.txt与c.txt的最新更新时间之后,从而判断它是否是最新版本,是否需要执行命令操作。

修改c.txt过后则会触发out.txt的执行命令

但并不会触发m.txt的更新,原因是m.txt的依赖a.txtb.txt并未更新,所以,make只会根据Makefile去执行那些必要的规则,并不会把所有规则都无脑执行一遍。

由于makefile会自动生成一些文件,比如上述的m.txt与out.txt,我们可以采用make clean命令去自动的删除它,需要编写一个clean规则去实现这一操作

clean:     rm -f m.txt      rm -f output.txt

如果我们手动创建一个clean的文件,这个clean规则就不会执行了!

如果我们希望makeclean不要视为文件,可以添加一个标识:

.PHONY: clean clean: 	rm -f m.txt 	rm -f x.txt

此时,clean就不被视为一个文件,而是伪目标(Phony Target)。

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!