这个要从Windows、Linux以及Unicode的历史说起了...
Windows98以前的系统,以及较早的Linux系统,只支持非Unicode字符集。
Windows 2000之后的系统,以及现在的Linux系统,都支持Unicode与非Unicode编码,但是支持的方式不一样。
Windows使用的是UCS2字符集,也就是一个Unicode字符用2个字节表示。
因为Windows是微软的,所以彻底重写并对外提供两种API是可行的。
Linux系统由于自身的特殊性,无法使用UCS2,因为Linux里面的库太多了,远不止Win32 API。
而且这些库也不是一个公司开发的,根本没有办法强行替换成UCS2编码,
所以就产生了UTF-8编码,一种可以很好兼容ANSI字符集的编码。
所以,并不是说VC不支持UTF-8,而是Windows操作系统本身就没有提供UTF-8编码的API。
但是,你仍然可以使用WideCharToMultiByte、MultiByteToWideChar在UTF-8, UCS2, ANSI之间进行转换。
Windows98以前的系统,以及较早的Linux系统,只支持非Unicode字符集。
Windows 2000之后的系统,以及现在的Linux系统,都支持Unicode与非Unicode编码,但是支持的方式不一样。
Windows使用的是UCS2字符集,也就是一个Unicode字符用2个字节表示。
因为Windows是微软的,所以彻底重写并对外提供两种API是可行的。
Linux系统由于自身的特殊性,无法使用UCS2,因为Linux里面的库太多了,远不止Win32 API。
而且这些库也不是一个公司开发的,根本没有办法强行替换成UCS2编码,
所以就产生了UTF-8编码,一种可以很好兼容ANSI字符集的编码。
所以,并不是说VC不支持UTF-8,而是Windows操作系统本身就没有提供UTF-8编码的API。
但是,你仍然可以使用WideCharToMultiByte、MultiByteToWideChar在UTF-8, UCS2, ANSI之间进行转换。