我正在编写一个与 mingw 一起使用的包装层,它为应用程序提供了虚拟 UTF-8 环境。处理文件名的函数是从 UTF-8 转换并调用相应的“_w”函数的包装器,依此类推。我遇到的最大问题是 Windowswchar_t是 16 位的。
对于文件系统操作来说,这不是什么大问题。我可以在 UTF-8 和 UTF-16 之间来回转换,一切都会正常。但标准 C 多字节/宽字符转换 API 不允许多 wchar_t 字符。
可能的解决方案:
wchar_t并typedef int32_t wchar_t;处理WCHAR和wchar_t不同。这很痛苦,但对于需要干净的 POSIX 类型环境且不用于wchar_t任何 Windows API 目的的移植应用程序来说,它可能是理想的选择。mbrtowcwchar_t读取 4 字节 UTF-8 字符的前 3 个字节后,输出对应于高代理项的值,并将剩余状态保留在mbstate_t对象中。收到下一个字节后,它将其与保存的状态组合以输出低代理。如果最后一个字节最终无效,它将返回 -1(使用 EILSEQ)并且一个单独的代理最终会出现在输出流中(坏...)。
wcrtomb当处理高位代理时,输出 UTF-8 的前 2 个字节,并将剩余状态保存在其mbstate_t对象中。当它随后处理低位代理时,它将其与保存的状态结合起来以输出 UTF-8 的最后 2 个字节。如果未收到有效的低代理项,它将返回 -1(使用 …