在Linux命令行中,我们要编译文件生成可执行程序,删除可执行文件要写一段代码
如果我们在测试一个文件时,每次都要这样写,那会显得十分的麻烦。因此熟练的使用makefile显得十分有用。
初步理解makefile
初见makefile
如果我们要使用makefile,我们需要在目标代码的文件目录中,添加一个 叫做makefile的文件,以下就是这个文件中的基础代码
之后如果我们要使用makefile,我们会在Linux命令行中输入以下指令
然后我们会得到以下结果
此时我们已获得我们的可执行文件test.exe
如果我们想清除这个文件,我们将执行以下
此时该可执行文件已被清除。
因此,makefile其实是个文件,而make是指令,当我们输入make指令时,系统会找到该目录下的makefile文件,执行里面要求的操作
原理
再回到makefile文件中
我们先只看前两行
第一行是两个文件的依赖关系,其中test.exe是目标文件,test.cc是依赖文件列表;第二行是依赖方法,既通过该方法可以得到目标文件test.exe。
我们再看看4,5行
这是一种特殊的依赖关系。
我们每次使用make时,它会默认从上到下去执行,直至生成目标文件,因此我们输入make,会执行第一个依赖关系的方法,它的效果和
是一样的
我们输入make clean就会执行第二个依赖关系的方法,从而删除目标文件。
可如果我们连续输入make,就会得到以下结果
因为makefile会自动检查test.cc的修改时间和test.exe的生成时间,如果test.cc的修改时间在test.exe的生成时间之前,就说明test.cc是没有修改的,因此在这时不会执行命令。
这又有什么用呢?
这表示clean方法总是要被执行的,这又是什么意思呢?
有的时候,clean下的方法可能因为一些原因不能执行,而加了.PHONY后,方法就一定可以执行。
再举个例子,如果我们代码中有 .PHONY:test.exe ,那我们连续make,系统就会总是执行我们的命令。
进阶
我们改写下
其中 $ @代指目标文件,$ ^ 代指依赖文件列表
我们也可以使用变量
如果我们不想显示
我么可以这么改写
这样我们在输入,就会这样