在Windows下有六種類型CRTLib(C運(yùn)行庫):
Reusable Library Switch Library Macro(s) Defined
----------------------------------------------------------------
Single Threaded /ML LIBC (none)
Static MultiThread /MT LIBCMT _MT
Dynamic Link (DLL) /MD MSVCRT _MT and _DLL
Debug Single Threaded /MLd LIBCD _DEBUG
Debug Static MultiThread /MTd LIBCMTD _DEBUG and _MT
Debug Dynamic Link (DLL) /MDd MSVCRTD _DEBUG, _MT, and _DLL
MT和MD都適用于多線程,其區(qū)別是:
MT為靜態(tài)鏈接CRT,這樣編譯出來exe是自包含的,所以會(huì)相對(duì)大一些,但運(yùn)行時(shí)不用再load CRT庫。
MD為動(dòng)態(tài)鏈接CRT,編譯出來exe會(huì)小一些,運(yùn)行時(shí)需要load CRT,性能有一點(diǎn)點(diǎn)損失。
任何工程都應(yīng)該使用同樣的CRT Library。即要么都是/ML,要么都是/MTD, 如此類推。
如果一個(gè)程序中混合使用不同類型的CRT,有時(shí)可以通過link,這樣會(huì)存在不同CRT的copy,并導(dǎo)致以下問題:
1)在一個(gè)lib中new出來內(nèi)存,在另一個(gè)lib中delete,會(huì)crash。
2)不能在多個(gè)lib中共享file handle。
3)一個(gè)lib中設(shè)置locale(本地化有關(guān)),不能在另一個(gè)lib中起作用。
當(dāng)工程比較大,包含的lib很多,特別當(dāng)有外部lib(Third party library)存在時(shí),link很容易發(fā)生下面這樣的錯(cuò)誤。
LIBCMTD.lib(chsize.obj) : error LNK2005: __chsize already defined in MSVCRTD.lib(MSVCRTD.dll)
這說明,你的工程使用了不同類型的CRT。這個(gè)時(shí)候首先一定要堅(jiān)信這個(gè)原則:整個(gè)工程用同樣的CRT Lib就可以解決問題。然后耐心一一檢查每個(gè)lib。
如果恰恰某個(gè)外部lib用MT,另一個(gè)用MD,這個(gè)時(shí)候就比較痛苦。
如果有他們?cè)创a,就編譯一個(gè)MT or MD類型的lib,以統(tǒng)一使用一個(gè)類型CRT。
如果沒有,那可能只好選擇其他的lib。
一般,我個(gè)人習(xí)慣將所有l(wèi)ib都編譯為MT。出于其他需要,會(huì)同時(shí)提供MT(MTd)和MD(MDd)兩種版本。
posted on 2008-04-23 14:31
水 閱讀(2725)
評(píng)論(2) 編輯 收藏 引用 所屬分類:
c/c++基礎(chǔ)知識(shí)