在Windows下有六種類型CRTLib(C運行庫):
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都適用于多線程,其區別是:
MT為靜態鏈接CRT,這樣編譯出來exe是自包含的,所以會相對大一些,但運行時不用再load CRT庫。
MD為動態鏈接CRT,編譯出來exe會小一些,運行時需要load CRT,性能有一點點損失。
任何工程都應該使用同樣的CRT Library。即要么都是/ML,要么都是/MTD, 如此類推。
如果一個程序中混合使用不同類型的CRT,有時可以通過link,這樣會存在不同CRT的copy,并導致以下問題:
1)在一個lib中new出來內存,在另一個lib中delete,會crash。
2)不能在多個lib中共享file handle。
3)一個lib中設置locale(本地化有關),不能在另一個lib中起作用。
當工程比較大,包含的lib很多,特別當有外部lib(Third party library)存在時,link很容易發生下面這樣的錯誤。
LIBCMTD.lib(chsize.obj) : error LNK2005: __chsize already defined in MSVCRTD.lib(MSVCRTD.dll)
這說明,你的工程使用了不同類型的CRT。這個時候首先一定要堅信這個原則:整個工程用同樣的CRT Lib就可以解決問題。然后耐心一一檢查每個lib。
如果恰恰某個外部lib用MT,另一個用MD,這個時候就比較痛苦。
如果有他們源碼,就編譯一個MT or MD類型的lib,以統一使用一個類型CRT。
如果沒有,那可能只好選擇其他的lib。
一般,我個人習慣將所有lib都編譯為MT。出于其他需要,會同時提供MT(MTd)和MD(MDd)兩種版本。
posted on 2008-04-23 14:31
水 閱讀(2709)
評論(2) 編輯 收藏 引用 所屬分類:
c/c++基礎知識