增量编译
在VC中就是增量编译!
当某个cpp更新后,只编译这个cpp文件,称为增量编译。
在Linux中,通过控制Makefile实现增量编译的效果
Makefile中使用“依赖dependency”来实现增量编译
target:dependencies
<TAB>system command1
<TAB>system command..
依赖是一个文件列表,当有文件更新时,执行这条规则
注意:根据文件的修改时间来判断是否要更新,
比如某个依赖文件的时间比target的时间要新就编译
特例:
时间比较:
target(T1):dependencies(T2)
1.若target文件不存在,则T1为0
2.若dependencies为空,则T2为0
Makefile比较T2与T1
if(T1==0)执行
else if(T2>T1)执行
else "已是最新,不执行规则"
举个栗子:
如下面的这个代码:
first.h
void firstPrint();
first.cpp
#include "first.h"
#include <stdio.h>
void firstPrint() {
printf("firstPrint called!\n");
}
second.h
void secondPrint();
second.cpp
#include "second.h"
#include <stdio.h>
void secondPrint() {
printf("secondPrint called!\n");
}
main.cpp
#include "first.h"
#include "second.h"
#include <stdio.h>
int main() {
firstPrint();
secondPrint();
printf("main called!\n");
return 0;
}
此时写一个Makefile,如下图:
helloWorld:main.o first.o second.o
g++ main.o first.o second.o -o helloWorld
main.o:main.cpp first.h second.h
g++ -c main.cpp -o main.o
first.o:first.cpp first.h
g++ -c first.cpp -o first.o
second.o:second.cpp second.h
g++ -c second.cpp -o second.o
clean:
rm -rf *.o
就是因为这样,就可以采用增量编译了!
如下,当第一次调用Makefile生成文件时:
第二次调用时候,他会提示,已经是最新的,如下图:
当修改了second.cpp中的文件后,注意看现象:
程序首先执行Makefile中的helloWorld:main.o first.o second.o,
编译helloWorld时,他先回去找main.o发现main.o没有啥改变就不管啦,他又去找first.o发现时间戳正常,也不去管了,找到second.o时候,发现最新的文件比他second的文件新,就执行:
second.o:second.cpp second.h
g++ -c second.cpp -o second.o
这个代码执行完后,才执行:
helloWorld:main.o first.o second.o
g++ main.o first.o second.o -o helloWorld