前言:对,我就是标题党,我也不太会写makefile,本篇只是入个门,只能教你写一些简单的makefile。
为什么要学makefile
make工具可以看成是一个智能的批处理工具,它本身并没有编译和链接的功能,而是用类似于批处理的方式—通过调用makefile文件中用户指定的命令来进行编译和链接的,所以在你写项目是,只需要编写一次,之后你编译的时候只用make一下就行了。
makefile命名规则:
- makefile
- Makefile
当然如果你不喜欢这个命名,偏要自己写名字,那也可以,但是就需要你在每次make时指定文件,用法如下
make -f 你写的makefile文件名
makefile三要素:
- 目标
- 依赖
- 规则命令
当然,这三要素也不一定全都要写出来,依赖和规则在特定情况下可以不写,而目标必须写。
写法:
在将写法之前,我先来说一下我的这个例子的目录结构,源代码请看我这篇帖子,除了头文件和目录格式稍微改了一下,内容没改,可以预先看一下头文件包含,其实不看也可以,主要是学写的方法。
include目录里面
下面来正式学习makefile的写法
标准格式:
目标:依赖
[tab键]规则命令
有了格式,所以我们就照着写法写出了一个很简单makefile,其实makefile的语法和写bash的比较像,学了bash在学makefile相对来说更好学一点。
第一版:
myString:myString.cpp Dbug.cpp
g++ -o myString -I./include myString.cpp Dbug.cpp
这时候在命令行输make执行,就会生成一个可执行文件myString,如果你的源码没有改变执行make会提示当前已经是最新的,不需要编译。
ps:make只关心.cpp和.o的时间差,不关心.h的时间差,也就是说如果只修改.h文件,make不会去重新编译这个.c文件。
这一版的makefile有弊