作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在努力将一些遗留的 C++ 代码移植到 Android 平台。这样做时,我注意到代码使用 iconv_xxx() 例程来处理 Unicode 转换。碰巧Android NDK默认没有iconv.h。我可以下载并构建 libiconv 的源代码。但是,我只是想知道,当几乎所有平台上的 C++ 编译器都支持 mbstowcs、wcstombs 时,为什么还要费心使用 iconv_xxx 函数。以及相关的套路。 iconv_xxx 函数是否比 mbsXXXwbsXXX 例程有任何优势?问候。
最佳答案
mb
/wc
函数在特定于平台的 wchar_t 编码和特定于平台和区域设置的多字节编码之间进行转换。
在 x86 上的 Linux 上,wc
很可能是 UTF-32LE,mb
很可能是 UTF-8,但远不能保证。在 Windows 上,wc
是 UTF-16LE; mb
很可能是机器的默认语言环境 (ANSI) 代码页,而且不太可能是 UTF-8。
因此,如果您想与已知的特定编码进行相互转换,则必须使用 iconv()
。
关于c++ - Unicode 转换 - iconv_xxx 与 mbstowcs/wcstombs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23071702/
我正在努力将一些遗留的 C++ 代码移植到 Android 平台。这样做时,我注意到代码使用 iconv_xxx() 例程来处理 Unicode 转换。碰巧Android NDK默认没有iconv.h
我是一名优秀的程序员,十分优秀!