不管VC還是GCC也好,.cpp文件多了,模板多了,那編譯速度也就慢了,有時(shí)會(huì)長(zhǎng)達(dá)10分鐘以上,甚至更長(zhǎng)。因?yàn)橹饕窃趌inux下開(kāi)發(fā),所以VC就不嘗試了。
有一天,突然想到,如果整個(gè)工程,只編譯一個(gè)文件,是不是可行?
然后,就手動(dòng)做了一個(gè)嘗試。
然后如下做:
首先寫(xiě)一個(gè).cxx文件,用#include把這些.cpp全部包含進(jìn)來(lái)
再修改makefile,去除.cpp,.CPP的目標(biāo)生成,增加.cxx。然后編譯,通過(guò)。(大概整個(gè)的時(shí)間,是原有整個(gè)時(shí)間的四分之一到五分之一,如果.cpp更多,時(shí)間相對(duì)更短)
最后再連接生成目標(biāo)文件
結(jié)果:目標(biāo)文件小很多,是原來(lái)的幾分之一。
這個(gè)有兩點(diǎn)擔(dān)心:
第一是程序是否是預(yù)期運(yùn)行
第二是調(diào)試信息會(huì)不會(huì)有影響
然后,我就嘗試程序,并完整跑通服務(wù)器,結(jié)果是完全沒(méi)有問(wèn)題。
最后,對(duì)程序進(jìn)行調(diào)試,各種GDB調(diào)試操作都OK了,和多個(gè)cpp下表現(xiàn)一樣。
嘗試完成后,就在程序應(yīng)用了。但是生成手動(dòng)就不方便了,就用python寫(xiě)了一個(gè)cxx工具,在有增加.cpp文件的時(shí)候,就可用它生成.cxx了。
嘗試成功后,在.cpp比較多的工程中,就使用這種辦法,總算是縮短不少編譯時(shí)間!(在cocos2dx,我也在考慮用同樣的辦法)
1 # -*- coding: utf-8 -*
2 #這個(gè)文件主要的作用是遍歷指定的目錄(包括子目錄),找出所有的.cpp文件 ,然后生成一個(gè)文件,將.cpp文件包含在指定文件中。
3 import os
4 import sys
5 import codecs
6
7 srclist = []
8
9 def ListDir(paramDir, paramRelativePath):
10 stItemList = os.listdir(paramDir)
11 for stItem in stItemList:
12 stItemFullName = os.path.join(paramDir, stItem)
13 if os.path.isdir(stItemFullName):
14 ListDir(stItemFullName, paramRelativePath + stItem + "/")
15 elif os.path.isfile(stItemFullName):
16 (stFilePath, stExt) = os.path.splitext(stItem)
17 if stExt.upper() == ".CPP":
18 srclist.append("#include \"" +paramRelativePath + stItem + "\"")
19
20 def CreateCxx(paramDest):
21 f = codecs.open(paramDest, "w", "utf-8")
22 for i in srclist:
23 f.write(i + "\n")
24 print i
25 f.write("\n")
26 print "\n"
27 f.close()
28
29 if __name__ == '__main__':
30 if len(sys.argv) < 3:
31 print 'Usage: %s srcdir destcxx' % sys.argv[0]
32 sys.exit(1)
33 ListDir(sys.argv[1], "")
34 CreateCxx(sys.argv[2])
35 print "Create " + sys.argv[2] + " finish!"
36