(转)_T()和L总结(ASCII/UNICODE)

来源:互联网 发布:采用js实现评论和回复 编辑:程序博客网 时间:2024/04/29 18:03

        Visual C++里边定义字符串的时候,用_T来保证兼容性,是一种数据类型,但是它不会产生结果,被编译系统的预处理系统来解释,VC支持ascii和unicode两种字符类型,用_T可以保证从ascii编码类型转换到unicode编码类型的时候,程序不需要修改。
        如果将来你不打算升级到unicode,那么也不需要_T!

        _T是将字符串转换为TCHARTCHAR是一个宏定义,当定义了UNICODE时TCHAR等同于 WCHAR,否则等同于CHAR。为了和以后的平台兼容,建议使用TCHAR,而不要使用普通的CHAR。例子:TCHAR *s = _T("FSDF")。
       L将字符串转换为WCHAR,用于需要UNICODE的环境。例子:WCHAR *s = L"FSDF"。

Example:

       SetWindowText(_T("我很好")); 
    在中文Win2000上正常,在英文Win2000下就是乱码! 
// _T()自动将()内字符串转成unicode or Multibyte-character or SBCS (ASCII) 根据系统宏定义, 
// 为了将程序与vb等unicode 编码的程序交互,为了程序的国际化,为了... 
// 看msdn! 如果定义了 UNICODE 就变成 L把字符串转换成宽字符,否则没用。 
// 统一的字符编码标准, 采用双字节对字符进行编码 
// _T把参数转换成当前系统支持的字符,例如支持UNICODE就转换成宽字符,否则就是单字符 
#ifdef UNICODE 
#define _T(x) L##x 
#else 
#define _T(x) x 
#endif 
_T/_TEXT是在TCHAR.H头文件中定义的宏。 
在_UNICODE和_MBCS都没有定义时,对其后的字符串无影响 
在_MBCS定义时,对其后的字符串无影响 
在_UNICODE定义时,其后的字符串被定义为 L(即转换为Unicode字符) 
本质上是为了生成Unicode和非Unicode通用的程序而定义的宏。 

Unicode:宽字节字符集..
1. 如何取得一个既包含单字节字符又包含双字节字符的字符串的字符个数? 
可以调用Microsoft Visual C++的运行期库包含函数_mbslen来操作多字节(既包括单字节也包括双字节)字符串。 
调用strlen函数,无法真正了解字符串中究竟有多少字符,它只能告诉你到达结尾的0之前有多少个字节。 
2. 如何对DBCS(双字节字符集)字符串进行操作? 
函数 描述 
PTSTR CharNext ( LPCTSTR ); 返回字符串中下一个字符的地址 
PTSTR CharPrev ( LPCTSTR, LPCTSTR ); 返回字符串中上一个字符的地址 
BOOL IsDBCSLeadByte( BYTE ); 如果该字节是DBCS字符的第一个字节,则返回非0值 
3. 为什么要使用Unicode? 
(1) 可以很容易地在不同语言之间进行数据交换。 
(2) 使你能够分配支持所有语言的单个二进制.exe文件或DLL文件。 
(3) 提高应用程序的运行效率。 
Windows 2000是使用Unicode从头进行开发的,如果调用任何一个Windows函数并给它传递一个ANSI字符串,那么系统首先要将字符串转换成 Unicode,然后将Unicode字符串传递给操作系统。如果希望函数返回ANSI字符串,系统就会首先将Unicode字符串转换成ANSI字符 串,然后将结果返回给你的应用程序。进行这些字符串的转换需要占用系统的时间和内存。通过从头开始用Unicode来开发应用程序,就能够使你的应用程序 更加有效地运行。 
Windows CE 本身就是使用Unicode的一种操作系统,完全不支持ANSI Windows函数 
Windows 98 只支持ANSI,只能为ANSI开发应用程序。 
Microsoft公司将COM从16位Windows转换成Win32时,公司决定需要字符串的所有COM接口方法都只能接受Unicode字符串。 
4. 如何编写Unicode源代码? 
Microsoft公司为Unicode设计了WindowsAPI,这样,可以尽量减少代码的影响。实际上,可以编写单个源代码文件,以便使用或者不使 用Unicode来对它进行编译。只需要定义两个宏(UNICODE和_UNICODE),就可以修改然后重新编译该源文件。 
_UNICODE宏用于C运行期头文件,而UNICODE宏则用于Windows头文件。当编译源代码模块时,通常必须同时定义这两个宏。 
5. Windows定义的Unicode数据类型有哪些? 
数据类型 说明 
WCHAR Unicode字符 
PWSTR 指向Unicode字符串的指针 
PCWSTR 指向一个恒定的Unicode字符串的指针 
对应的ANSI数据类型为CHAR,LPSTR和LPCSTR。 
ANSI/Unicode通用数据类型为TCHAR,PTSTR,LPCTSTR。 
6. 如何对Unicode进行操作? 
字符集 特性 实例 
ANSI 操作函数以str开头 strcpy 
Unicode 操作函数以wcs开头 wcscpy 
MBCS 操作函数以_mbs开头 _mbscpy 
ANSI/Unicode 操作函数以_tcs开头 _tcscpy(C运行期库) 
ANSI/Unicode 操作函数以lstr开头 lstrcpy(Windows函数) 
所有新的和未过时的函数在Windows2000中都同时拥有ANSI和Unicode两个版本。ANSI版本函数结尾以A表示;Unicode版本函数结尾以W表示。Windows会如下定义: 
#ifdef UNICODE 
#define CreateWindowEx CreateWindowExW 
#else 
#define CreateWindowEx CreateWindowExA 
#endif // !UNICODE 
7. 如何表示Unicode字符串常量? 
字符集 实例 
ANSI “string” 
Unicode L“string” 
ANSI/Unicode T(“string”)或_TEXT(“string”)if( szError[0] == _TEXT(‘J’) ){ } 
8. 为什么应当尽量使用操作系统函数? 
这将有助于稍稍提高应用程序的运行性能,因为操作系统字符串函数常常被大型应用程序比如操作系统的外壳进程Explorer.exe所使用。由于这些函数使用得很多,因此,在应用程序运行时,它们可能已经被装入RAM。 
如:StrCat,StrChr,StrCmp和StrCpy等。 
9. 如何编写符合ANSI和Unicode的应用程序? 
(1) 将文本串视为字符数组,而不是chars数组或字节数组。 
(2) 将通用数据类型(如TCHAR和PTSTR)用于文本字符和字符串。 
(3) 将显式数据类型(如BYTE和PBYTE)用于字节、字节指针和数据缓存。 
(4) 将TEXT宏用于原义字符和字符串。 
(5) 执行全局性替换(例如用PTSTR替换PSTR)。 
(6) 修改字符串运算问题。例如函数通常希望在字符中传递一个缓存的大小,而不是字节。这意味着不应该传递sizeof(szBuffer),而应该传递 (sizeof(szBuffer)/sizeof(TCHAR)。另外,如果需要为字符串分配一个内存块,并且拥有该字符串中的字符数目,那么请记住要 按字节来分配内存。这就是说,应该调用malloc(nCharacters *sizeof(TCHAR)),而不是调用malloc(nCharacters)。 
10. 如何对字符串进行有选择的比较? 
通过调用CompareString来实现。 
标志 含义 
NORM_IGNORECASE 忽略字母的大小写 
NORM_IGNOREKANATYPE 不区分平假名与片假名字符 
NORM_IGNORENONSPACE 忽略无间隔字符 
NORM_IGNORESYMBOLS 忽略符号 
NORM_IGNOREWIDTH 不区分单字节字符与作为双字节字符的同一个字符 
SORT_STRINGSORT 将标点符号作为普通符号来处理 
11. 如何判断一个文本文件是ANSI还是Unicode? 
判断如果文本文件的开头两个字节是0xFF和0xFE,那么就是Unicode,否则是ANSI。 
12. 如何判断一段字符串是ANSI还是Unicode? 
用IsTextUnicode进行判断。IsTextUnicode使用一系列统计方法和定性方法,以便猜测缓存的内容。由于这不是一种确切的科学方法,因此 IsTextUnicode有可能返回不正确的结果。 
13. 如何在Unicode与ANSI之间转换字符串? 
Windows函数MultiByteToWideChar用于将多字节字符串转换成宽字符串;函数WideCharToMultiByte将宽字符串转换成等价的多字节字符串。

 

 

转自:http://hi.baidu.com/jikejlm/blog/item/e3b4c710e851b8fac3ce79ed.html

原创粉丝点击