今天在網(wǎng)上看到一篇VC項(xiàng)目管理的文章,感覺(jué)非常有用。特別是對(duì)大、中型項(xiàng)目的規(guī)范化、條理化管理非常有幫助,特轉(zhuǎn)貼這里。
VC 2005 解決方案的目錄結(jié)構(gòu)設(shè)置和管理
Roger (roger2yi@gmail.com)
一個(gè)中等規(guī)模的解決方案通常都會(huì)包含多個(gè)項(xiàng)目,其中一些項(xiàng)目產(chǎn)出靜態(tài)庫(kù),一些產(chǎn)出動(dòng)態(tài)庫(kù),一些用于單元測(cè)試,還有的產(chǎn)出最終的應(yīng)用程序執(zhí)行檔。除此以外,根據(jù)項(xiàng)目的需求,還會(huì)使用一些第三方的庫(kù)。
所以為解決方案設(shè)置一個(gè)合理的目錄結(jié)構(gòu),不但可以使得代碼管理更井井有條,項(xiàng)目成員之間也更容易相互配合,更重要的是能夠使得最終應(yīng)用程序的安裝包制作,源代碼打包發(fā)布和轉(zhuǎn)移變得十分容易。
解決方案與項(xiàng)目:
從VC6之后VC系列就使用解決方案(Solution)來(lái)替代原來(lái)的工作空間,用于組織和管理多個(gè)相關(guān)的項(xiàng)目(Project)。
文章首先演示一個(gè)虛擬的解決方案和我們期望得到的目錄結(jié)構(gòu),然后使用VC2005的項(xiàng)目設(shè)置功能來(lái)一步一步達(dá)到我們的需求。
虛擬解決方案:
該虛擬解決方案名為GMA,包含一個(gè)動(dòng)態(tài)鏈接庫(kù)項(xiàng)目ChocolateMilk和一個(gè)應(yīng)用程序項(xiàng)目PureMilk,需要使用一個(gè)第三方庫(kù)log4cxx(Apache log4j的C++移植版本,用于日志輸出)。
log4cxx是以動(dòng)態(tài)庫(kù)的方式編譯的,所以我們需要它的3樣?xùn)|西,分別是頭文件,導(dǎo)入庫(kù)(log4cxx.lib, log4cxxd.lib)和動(dòng)態(tài)鏈接庫(kù)(log4cxx.dll)。
假設(shè)我們期望的目錄結(jié)構(gòu)如下圖:

1. GMA是解決方案目錄
2. PureMilk和ChocolateMilk是項(xiàng)目目錄
3. Lib目錄用于存放導(dǎo)入庫(kù)或者靜態(tài)庫(kù)(包括第三方庫(kù)和自己的項(xiàng)目)
4. Include用于存放第三方庫(kù)的頭文件
5. Bin目錄存放所有動(dòng)態(tài)鏈接庫(kù)和執(zhí)行檔,包括自己的產(chǎn)出和第三方庫(kù),區(qū)分Release和Debug兩個(gè)版本。另外,程序運(yùn)行過(guò)程中需要外部的數(shù)據(jù)文件和啟動(dòng)時(shí)需要的配置文件等等都可放于該目錄
6. Temp用于存放臨時(shí)生成文件,其中Compile存放編譯器編譯時(shí)生成的obj文件,Link存放鏈接器的輸出文件。
上面目錄結(jié)構(gòu)清晰,一面了然,當(dāng)我們的程序需要制作安裝包或者要打包源碼
發(fā)布的時(shí)候,它能夠使得我們生活變得更容易^_^
制作安裝包時(shí)我們只需將“/GMA/Bin/Release/”目錄下的所有文件打包。
發(fā)布和轉(zhuǎn)移源碼的時(shí)候我們可以打包除了Temp目錄以外“/GMA/”下面的所有文件和目錄(如果不需要執(zhí)行檔,也可不包括Bin)。
我們的需求是明確的,可是VC 2005并不會(huì)自動(dòng)為我們做好上面所有的事情。不過(guò)我們并不需要編寫(xiě)復(fù)雜的編譯腳本(makefile),只需要簡(jiǎn)單的修改項(xiàng)目的缺省設(shè)置即可。
我們需要VC為我們做的事情包括:
1.使用“/GMA/Temp/Compile/”作為項(xiàng)目編譯時(shí)使用的中間目錄
2.使用“/GMA/Temp/Link/”作為項(xiàng)目鏈接的輸出目錄
3.當(dāng)項(xiàng)目是應(yīng)用程序時(shí),在構(gòu)建結(jié)束后拷貝執(zhí)行文件到“/GMA/Bin/Release/”或“/GMA/Bin/Debug/”,當(dāng)項(xiàng)目是動(dòng)態(tài)鏈接庫(kù)時(shí),除了拷貝dll到Bin,還拷貝導(dǎo)入庫(kù)到“/GMA/Lib/”
4.當(dāng)項(xiàng)目是應(yīng)用程序時(shí),調(diào)試時(shí)運(yùn)行“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”下面的執(zhí)行文件,并以“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”為工作目錄
首先看一下項(xiàng)目設(shè)置中可以使用的宏,常用的有:
ConfigurationName |
配置名字,通常是Debug或者Release
|
IntDir |
編譯器使用的中間目錄,產(chǎn)出obj文件
|
OutDir |
鏈接器使用的輸出目錄 |
ProjectDir |
項(xiàng)目目錄 |
ProjectName |
項(xiàng)目名字 |
SolutionDir |
解決方案目錄 |
TargetDir |
目標(biāo)輸出文件所在的目錄 |
TargetExt |
目標(biāo)輸出的擴(kuò)展名 |
TargetFileName |
目標(biāo)輸出文件名,包括擴(kuò)展名 |
TargetName |
目標(biāo)輸出名,不包括擴(kuò)展名 |
TargetPath |
目標(biāo)輸出文件的全路徑名 |

首先來(lái)設(shè)置ChocolateMilk:
1.使用“/GMA/Temp/Compile/”作為項(xiàng)目編譯時(shí)使用的中間目錄
2.使用“/GMA/Temp/Link/”作為項(xiàng)目鏈接的輸出目錄
注意高亮的部分,首先將配置改成All Configuration(全部配置),這樣可以讓我們同時(shí)修改Debug和Release的部分;
Output Directory(輸出目錄,鏈接器)欄位填入:
$(SolutionDir)\Temp\Link\$(ProjectName)\$(ConfigurationName)
Intermediate Directory(中間目錄,編譯器)欄位填入:
$(SolutionDir)\Temp\Compile\$(ProjectName)\$(ConfigurationName)
3.構(gòu)建結(jié)束后拷貝動(dòng)態(tài)鏈接庫(kù)到“/GMA/Bin/Release/”或“/GMA/Bin/Debug/”,拷貝導(dǎo)入庫(kù)到“/GMA/Lib/”
我們通常都會(huì)在Debug版本的輸出庫(kù)后面加上字母“d”以表示這是Debug版本,在Debug配置下,修改Import Library欄位:
VC可以讓我們?cè)O(shè)置構(gòu)建前后執(zhí)行的腳本程序,所以為了完成3,
我們需要寫(xiě)構(gòu)建后執(zhí)行的腳本:
在Command Line中填入,Debug配置下:
copy $(TargetPath) $(SolutionDir)\Bin\$(ConfigurationName)\;
copy $(TargetDir)$(TargetName)d.lib $(SolutionDir)\Lib\;
Release配置下:
copy $(TargetPath) $(SolutionDir)\Bin\$(ConfigurationName)\;
copy $(TargetDir)$(TargetName).lib $(SolutionDir)\Lib\;
之所以要分別設(shè)置是因?yàn)閂C沒(méi)有表示導(dǎo)入庫(kù)的宏名字 -_-P
OK,到此為止,你就可以編譯ChocolateMilk項(xiàng)目試試是不是一切正常了,不過(guò)請(qǐng)確認(rèn)拷貝的目標(biāo)目錄事先建立好。
接下來(lái)我們?cè)O(shè)置應(yīng)用程序項(xiàng)目PureMilk:
1.使用“/GMA/Temp/Compile/”作為項(xiàng)目編譯時(shí)使用的中間目錄
2.使用“/GMA/Temp/Link/”作為項(xiàng)目鏈接的輸出目錄
首先將配置改成All Configuration(全部配置),這樣可以讓我們同時(shí)修改Debug和Release的部分;
Output Directory(輸出目錄,鏈接器)欄位填入:
$(SolutionDir)\Temp\Link\$(ProjectName)\$(ConfigurationName)
Intermediate Directory(中間目錄,編譯器)欄位填入:
$(SolutionDir)\Temp\Compile\$(ProjectName)\$(ConfigurationName)
3.構(gòu)建結(jié)束后拷貝執(zhí)行文件到“/GMA/Bin/Release/”或“/GMA/Bin/Debug/”
在Command Line中填入,All配置下:
copy $(TargetPath) $(SolutionDir)\Bin\$(ConfigurationName);
4.調(diào)試時(shí)運(yùn)行“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”下面的執(zhí)行文件,并以“/GMA/Bin/Debug/”或“/GMA/Bin/Release/”為工作目錄
Command欄位填入:$(SolutionDir)\Bin\$(ConfigurationName)\$(TargetFileName)
Working Directory欄位填入:$(SolutionDir)\Bin\$(ConfigurationName)\
這樣就大功告成了,現(xiàn)在你就可以編譯該執(zhí)行程序并進(jìn)行調(diào)試。
補(bǔ)充1:
各位兄弟們,那個(gè)copy的問(wèn)題我終于解決了,原來(lái)當(dāng)目標(biāo)路徑的文件夾不存在時(shí),copy命令就不好用了,提示系統(tǒng)找不到指定的路徑。,把這句話:
copy $(TargetPath) $(SolutionDir)\Bin\$(ConfigurationName)\;
換成以下這句就OK了……
xcopy $(TargetPath) $(SolutionDir)\Bin\$(ConfigurationName)\
注意,命令變成了xcopy了,而且最后的分號(hào)去掉啦,之后即使Bin目錄下沒(méi)有Debug或Release目錄編譯器也會(huì)自動(dòng)生成的!~
補(bǔ)充2:
避免下次編譯覆蓋文件提示加個(gè)“/y” 參數(shù),具體修改如下:
xcopy $(TargetPath) $(SolutionDir)\Bin\$(ConfigurationName)\ /y
這回就OK了,如果目標(biāo)文件正在被使用中的話,會(huì)提示“共享侵犯”哦!~
本文來(lái)自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/rogeryi/archive/2007/01/13/1481923.aspx