Makefile学习笔记

Makefile学习笔记

先列出一个很简单的Makefile例子:

---------
hd.cpp

#include "hd.h"

using namespace std;

int main() {
cout << "hello, didier!1\n";
}

---------
hd.h

#include <iostream>

---------
Makefile //我们称这个为Makefile1

hd : hd.cpp //注意,我没写hd.h
g++ -o hd hd.cpp

---------
make命令编译,当然没问题。但是注意,第一行我没有用如下写法:

hd : hd.cpp hd.h
所以Makefile1中,hd(可执行程序)不依赖于hd.h,只依赖于hd.cpp。编译通过是因为在Makefile1中第二行调用g++时,编译hd.cpp时会include "hd.h"。

这样乍看没问题,实际上有很大的问题,Makefile1中hd不依赖于hd.h,意思是说,如果这时候我修改hd.h,再make,make程序依然只检测hd.cpp的版本,发现没变化,所以不会调用第二行的g++命令。测试,果然如此。无论怎么修改hd.h,再次调用make是没有动作的。

不要以为在.cpp中会include头文件就可以不在Makefile中写依赖.h文件。这样得到的结论,或者说启发,就是,在一个工程中会有很多的文件依赖关系,会有很多程序员参与编码,如果修改了所依赖的文件,我们当然希望重新编译,所以,不要偷懒,在Makefile中一定要写全依赖关系。

比如这个例子,正确的写法:

---------
Makefile //我们称这个为Makefile2

hd : hd.cpp hd.h
g++ -o hd hd.cpp
---------

要搞清楚的是,Makefile2中,第一行所陈列的关系,就是希望make每次运行所要检测的文件版本变化,第二行,是希望所要执行的命令。Makefile2的依赖关系很全,每次修改hd.h,make都会重新执行。

当然,如果不用make,直接在命令行中输入调用g++,那么.h的修改当然会被重新编译了。

最后总结,在Makefile的编写中,每一个编译文件一定要写全其依赖关系,即使在cpp中会包含头文件。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。