UNICODE已定义,_tcs*函数却不是宽字符函数问题
一个比较大的项目,CMake里定义了UNICODE,调用Windows的API也是用W的版本。但调用_tcs*函数时,发现调用的是多字节版本,而不是宽字符版本。
例如,调用GetFileAttributes,是调用的GetFileAttributesW, 但调用_tcslen调用的是strlen 。
原因是API根据UNICODE宏区分,tchar.h里_tcs*函数,是根据_UNICODE宏区分。
查看Visual Studio的项目的属性-配置属性-高级-高级属性-字符集,可以看到,是“使用多字节字符集”。
所以如果在CMake文件里定义UNICODE,在Windows下会出现这种矛盾,使用的是宽字符API,tchar函数却是多字节版本。
UNICODE defined.
_UNICODE not defined.
_MBCS defined.
这种情况很显然,让人迷惑, 莫名其妙。
经测试,CMake文件里什么也不定义,生成的VS工程是默认用“多字节字符集”的。
UNICODE not defined.
_UNICODE not defined.
_MBCS defined.
如果CMake文件里定义了_UNICODE, 生成的VS工程是用“Unicode字符集”的。
UNICODE defined.
_UNICODE defined.
_MBCS not defined.
可以看到定义了_UNICODE,UNICODE会自动定义。
从前面看,定义了UNICODE,_UNICODE不会自动定义。
所以CMake文件里,如果需要区分Unicode字符集或多字节字符集,只需要添加或不添加_UNICODE定义即可。
从前面看,只定义UNICODE,会产生奇怪的情况,代码用的字符集是多字节字符集。
另外根据微软文档,_UNICODE和_MBCS都定义产生结果是不确定的,所以不要作死。