_T

转载 2011年01月23日 14:00:00

_T

  _T("")是一个宏,定义于tchar.h下。[1]  #define __T(x) L ## x  #define _T(x) __T(x)  他的作用是让你的程序支持Unicode编码  因为Windows使用两种字符集ANSI和UNICODE,  前者就是通常使用的单字节方式,  但这种方式处理象中文这样的双字节字符不方便,  容易出现半个汉字的情况。  而后者是双字节方式,方便处理双字节字符。  Windows NT的所有与字符有关的函数都提供两种方式的版本,而Windows 9x只支持ANSI方式。  如果你编译一个程序为ANSI方式,  _T实际不起任何作用。  而如果编译一个程序为UNICODE方式,则编译器会把"Hello"字符串以UNICODE方式保存。_T和_L的区别在于,_L不管你是以什么方式编译,一律以UNICODE方式保存。  LPSTR:32bit指针指向一个字符串,每个字符占1字节  LPCSTR:32-bit指针指向一个常字符串,每个字符占1字节  LPCTSTR:32-bit指针指向一个常字符串,每字符可能占1字节或2字节,取决于Unicode是否定义  LPTSTR:32-bit指针每字符可能占1字节或2字节,取决于Unicode是否定义  L是表示字符串资源为Unicode的。  比如  wchar_t Str[] = L"Hello World!";  这个就是双子节存储字符了。  _T是一个适配的宏~  当  #ifdef _UNICODE的时候  _T就是L  没有#ifdef _UNICODE的时候  _T就是ANSI的。  比如  LPTSTR lpStr = new TCHAR[32];  TCHAR* szBuf = _T("Hello");  以上两句使得无论是在UNICODE编译条件下都是正确编译的。  而且MS推荐你使用相匹配的字符串函数。  比如处理LPTSTR或者LPCTSTR 的时候,不要用strlen ,而是要用_tcslen  否则在UNICODE的编译条件下,strlen不能处理 wchar_t*的字符串。  T是非常有意思的一个符号(TCHAR、LPCTSTR、LPTSTR、_T()、_TEXT()...),它表示使用一种中间类型,既不明确表示使用 MBCS,也不明确表示使用 UNICODE。那到底使用哪种字符集?编译的时候才决定

相关文章推荐

stm32f030c8t6手册

POJ 1061 青蛙的约会

Description 两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面。它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止。可是它们出发之前忘记了一件很重要的...

RX23T技术文档

  • 2017-10-04 11:29
  • 51.99MB
  • 下载

命令行参数wmain (int argc,wchar_t *argv[])

#include #include #include #include //让wprintf()支持中文 #pragma comment(lib,"shell32.lib") int wmain...

T4m+for+unity5.6.2

  • 2017-09-18 21:55
  • 8.24MB
  • 下载

endnote 制作GB/T7714《文后参考文献著录规则》的输出格式

在引用文献时,绝大多数时候都要考虑文后参考文献的格式怎么写。如果是在中国,专门有一部国家推荐标准GB/T 7714 《文后参考文献著录规则》规范文后参考文献的格式。在中国,著名的文献管理软件endno...
  • swqqcs
  • swqqcs
  • 2012-05-18 16:25
  • 1952
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)