经常使用_T()宏,它是怎么来的?用VA看了一下,原来_T是__T
#define _T(x) __T(x)
再看看__T
在tchar.h中
#ifdef _UNICODE
#define __T(x) L ## x
#else
#define __T(x) x
#endif
那么,这个##是什么呢?原来它是一个连接符,将##左右两边的表达式连接成一个.比如,在_UNICODE环境下,
_T(“Unicode“) == L“Unicode“
不过需要注意的是,宏是由编译器在编译阶段识别的,所以不能指望程序运行时起到连接作用.比如:
int A0, A1, A2, A3;
for (int i = 0; i < 4; i++)
{
A##i = i;
}
这种代码就无法编译了.
解析_T()宏及编译器宏连接符
博客主要探讨了_T()宏的来源,发现_T是__T的定义。在tchar.h中,__T根据_UNICODE的定义有所不同。同时介绍了##是连接符,可将左右表达式连接。但强调宏由编译器在编译阶段识别,运行时无法起到连接作用,并给出示例代码。





