VC C運行時庫(CRTL)的幾個版本及選用
Michael 2006年7月27日于突尼斯
VC++ C運行時庫(以下簡稱CRTL)是指LIBC.LIB/LIBCMT.LIB/MSVCRT.LIB以及他們對應的DEBUG版本(在名稱后面加"D")。
在VC++ 4.2以前的版本中CRTL包含了C++的iostream庫函數(shù),但是在4.2及以后的版本中(添加了對C++標準庫的支持),iostream庫函數(shù)被獨立出來,為支持老的iostream和新的標準iostream函數(shù),4.2及后續(xù)版本存在兩套iostream庫,分別是(老的)LIBCI.LIB/LIBCIMT.LIB/MSVCIRT.LIB和(新的)LIBCP.LIB/LIBCPMT.LIB/MSVCPRT.LIB。針對DEBUG版本,分別存在名稱后加"D"的對應庫。并且新老的iostream庫是不兼容的,不能在同一個應用中混合使用。
一 版本特性列表
對CRTL的幾個版本及特性列表(RELEASE&DEBUG Version)如下:
RELEASE版本:
DEBUG版本:
二 單線程(Single threaded)和多線程(Multithreaded)的區(qū)別
簡單地說,單線程版本提供的CRTL函數(shù)不是可重入(Re-entrant)的(只有少部分函數(shù)是可重入),多線程版本提供的CRTL函數(shù)是可重入的。
對于多線程應用程序來說,如果使用單線程的CRTL將可能導致數(shù)據(jù)崩潰,因為在同一時間可能有多個線程同時訪問CRTL函數(shù)中的某個靜態(tài)數(shù)據(jù),這個數(shù)據(jù)在單線程CRTL中不受保護(如果訪問的是棧數(shù)據(jù),則沒有問題,因為棧的數(shù)據(jù)在每個獨立線程中分配)。所以,此時需要使用多線程的CRTL,如果堅持使用單線程CRTL,應用程序必須親自對數(shù)據(jù)共享訪問進行保護處理,比如設立臨界區(qū)。
三 靜態(tài)鏈接(Static link)和動態(tài)鏈接(Dynamic link)的區(qū)別
采用靜態(tài)鏈接的應用程序發(fā)布后不依賴于CRTL,同時該庫中的代碼和數(shù)據(jù)在該應用程序調(diào)用的其他動態(tài)庫中是訪問不到的。
采用動態(tài)鏈接的應用程序必須依賴于CRTL(比如MSVCRT.DLL)。
對于動態(tài)鏈接CRTL的應用程序,在調(diào)用庫函數(shù)時需要遵守兩個原則:1)調(diào)用習慣為C(__cdecl)習慣;2)函數(shù)參數(shù)類型為值或者指針類型。
【完】
Michael 2006年7月27日于突尼斯
VC++ C運行時庫(以下簡稱CRTL)是指LIBC.LIB/LIBCMT.LIB/MSVCRT.LIB以及他們對應的DEBUG版本(在名稱后面加"D")。
在VC++ 4.2以前的版本中CRTL包含了C++的iostream庫函數(shù),但是在4.2及以后的版本中(添加了對C++標準庫的支持),iostream庫函數(shù)被獨立出來,為支持老的iostream和新的標準iostream函數(shù),4.2及后續(xù)版本存在兩套iostream庫,分別是(老的)LIBCI.LIB/LIBCIMT.LIB/MSVCIRT.LIB和(新的)LIBCP.LIB/LIBCPMT.LIB/MSVCPRT.LIB。針對DEBUG版本,分別存在名稱后加"D"的對應庫。并且新老的iostream庫是不兼容的,不能在同一個應用中混合使用。
一 版本特性列表
對CRTL的幾個版本及特性列表(RELEASE&DEBUG Version)如下:
RELEASE版本:
CRTL (without iostream) | 特性 | VC編譯選項 | 預編譯宏 |
LIBC.LIB | Single threaded, static link | /ML | |
LIBCMT.LIB | Multithreaded, static link | /MT | _MT |
MSVCRT.LIB | Multithreaded, dynamic link (import library for MSVCRT.DLL),對于不同的VC版本對應的DLL名稱不一: VC1.0-MSVCRT10.DLL VC2.0-MSVCRT20.DLL VC4.0-MSVCRT40.DLL VC4.2-MSVCRT.DLL VC5.0-MSVCRT.DLL VC6.0-MSVCRT.DLL | /MD | _MT, _DLL |
Standard C++ Library | Characteristics | Option | Defined |
LIBCP.LIB | Single threaded, static link | /ML | |
LIBCPMT.LIB | Multithreaded, static link | /MT | _MT |
MSVCPRT.LIB | Multithreaded, dynamic link (import library for MSVCRT.DLL),對于不同的VC版本對應的DLL名稱不一: VC4.2-MSVCPRT.DLL VC5.0-MSVCP50.DLL VC6.0-MSVCP60.DLL | /MD | _MT, _DLL |
Old Iostream Library | Characteristics | Option | Defined |
LIBCI.LIB | Single threaded, static link | /ML | |
LIBCIMT.LIB | Multithreaded, static link | /MT | _MT |
MSVCIRT.LIB | Multithreaded, dynamic link (import library for MSVCIRT.DLL) | /MD | _MT, _DLL |
DEBUG版本:
CRTL(without iostream) | Characteristics | Option | Defined | |
LIBCD.LIB | Single-threaded, static link | /MLd | _DEBUG | |
LIBCMTD.LIB | Multithreaded, static link | /MTd | _DEBUG, _MT | |
MSVCRTD.LIB | Multithreaded, dynamic link (import library for MSVCRxD.DLL)1 | /MDd | _DEBUG, _MT, _DLL | |
1???In place of the “x” in the DLL name, substitute the major version numeral of Visual C++ that you are using. For example, if you are using Visual C++ version 4, then the library name would be MSVCR40D.DLL. |
Standard C++ Debug Library | Characteristics | Option | Defined |
LIBCPD.LIB | Single-threaded, static link | /MLd | _DEBUG |
LIBCPMTD.LIB | Multithreaded, static link | /MTd | _DEBUG, _MT |
MSVCPRTD.LIB | Multithreaded, dynamic link (import library for MSVCRTD.DLL),對于不同的VC版本對應的DLL名稱不一: VC4.2-MSVCPRTD.DLL VC5.0-MSVCP50D.DLL VC6.0-MSVCP60D.DLL | /MDd | _DEBUG, _MT, _DLL |
iostream Debug Library | Characteristics | Option | Defined |
LIBCID.LIB | Single threaded, static link | /MLd | _DEBUG |
LIBCIMTD.LIB | Multithreaded, static link | /MTd | _DEBUG, _MT |
MSVCIRTD.LIB | Multithreaded, dynamic link (import library for MSVCIRTD.DLL) | /MDd | _DEBUG, _MT, _DLL |
二 單線程(Single threaded)和多線程(Multithreaded)的區(qū)別
簡單地說,單線程版本提供的CRTL函數(shù)不是可重入(Re-entrant)的(只有少部分函數(shù)是可重入),多線程版本提供的CRTL函數(shù)是可重入的。
對于多線程應用程序來說,如果使用單線程的CRTL將可能導致數(shù)據(jù)崩潰,因為在同一時間可能有多個線程同時訪問CRTL函數(shù)中的某個靜態(tài)數(shù)據(jù),這個數(shù)據(jù)在單線程CRTL中不受保護(如果訪問的是棧數(shù)據(jù),則沒有問題,因為棧的數(shù)據(jù)在每個獨立線程中分配)。所以,此時需要使用多線程的CRTL,如果堅持使用單線程CRTL,應用程序必須親自對數(shù)據(jù)共享訪問進行保護處理,比如設立臨界區(qū)。
三 靜態(tài)鏈接(Static link)和動態(tài)鏈接(Dynamic link)的區(qū)別
采用靜態(tài)鏈接的應用程序發(fā)布后不依賴于CRTL,同時該庫中的代碼和數(shù)據(jù)在該應用程序調(diào)用的其他動態(tài)庫中是訪問不到的。
采用動態(tài)鏈接的應用程序必須依賴于CRTL(比如MSVCRT.DLL)。
對于動態(tài)鏈接CRTL的應用程序,在調(diào)用庫函數(shù)時需要遵守兩個原則:1)調(diào)用習慣為C(__cdecl)習慣;2)函數(shù)參數(shù)類型為值或者指針類型。
【完】