STL的string和wstring
STL有字符串處理類——stirng和wstring,但是用的時候會覺得不是很方便,因為它不能像TCHAR一樣根據定義的宏在char類型字符串和wchar_t進行轉換,總不能因為程序要Unicode就把所有類型轉換一遍吧?有沒有好辦法?
答案當然是肯定的,先看看MS的TCHAR是怎么做的,以下摘自MS Platform 的tchar.h,略有刪減
#ifdef _UNICODE
#ifdef __cplusplus
} /* ... extern "C" */
#endif
/* ++++++++++++++++++++ UNICODE ++++++++++++++++++++ */
#include <wchar.h>
#ifdef __cplusplus
extern "C" {
#endif
#if !__STDC__
typedef wchar_t TCHAR;
#endif
...
#ifdef _MBCS
/* ++++++++++++++++++++ MBCS ++++++++++++++++++++ */
#ifdef __cplusplus
} /* ... extern "C" */
#endif
#include <mbstring.h>
#ifdef __cplusplus
extern "C" {
#endif
#ifndef __TCHAR_DEFINED
typedef char _TCHAR;
typedef signed char _TSCHAR;
#if !__STDC__
typedef char TCHAR;
#endif
看到了吧,TCHAR就是根據_MBCS和_UNICODE宏來作為char和wchar_t的typedef。
下面再看看string和wstring兩個類:
typedef basic_string<char, char_traits<char>, allocator<char> >
string;
typedef basic_string<wchar_t, char_traits<wchar_t>,
allocator<wchar_t> > wstring;
原來string和wstring也是個typedef,都是模板basic_string的具現,既然只是個模板具現,那么其實現是不依賴于具體類型的,這也就是模板的意義——把實現從具體類型中抽象出來。
那么我們可以自己做個tstring:
typedef basic_string<TCHAR, char_traits<TCHAR>,
allocator<TCHAR> > tstring;
這樣tstring就可以根據宏的不同而成為string或wstring,用的時候只需要定義需要的宏,不用大面積修改代碼了。
模板賦予了STL強大的功能,一個通用的庫肯定不能包容所有需要,但是良好的庫應該有良好的擴展性,像string、wstring,既然不能滿足日常開發中靈活的轉換,那么我們就自己動手,具現一個tstring,stirng中所有的成員函數、算法都不用實現,除非你有特殊需要,因為模板已經將這些函數、算法都實現好了,我們要做的只需要具現就好了。
其實不止string和wstring,fstream和wfstream也可以像string和wstring一樣,通過basic_fstream模板具現一個tfstream
這就是模板強大的威力,也只有C++擁有如此強大的能力。
RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成