std::btowc
来自cppreference.com
在标头 <cwchar> 定义
|
||
std::wint_t btowc( int c ); |
||
加宽单字节字符 c 为其宽字符等价物。
大多数多字节字符编码用单字节码表示来自 ASCII 字符集的字符。此函数可用于转换这种字符为 wchar_t。
参数
c | - | 要加宽的单字节字符 |
返回值
若 c 为 EOF 则为 WEOF。
若 (unsigned char)c 在初始迁移状态为合法单字节字符,则为 c 的宽字符表示,否则为 WEOF。
示例
运行此代码
#include <clocale> #include <cwchar> #include <iostream> void try_widen(char c) { std::wint_t w = std::btowc(c); if (w != WEOF) std::cout << "单字节字符 " << +(unsigned char)c << " 被加宽为 " << +w << '\n'; else std::cout << "单字节字符 " << +(unsigned char)c << " 加宽失败\n"; } int main() { std::setlocale(LC_ALL, "lt_LT.iso88594"); std::cout << std::hex << std::showbase << "在立陶宛语 ISO-8859-4 本地环境中:\n"; try_widen('A'); try_widen('\xdf'); // ISO-8859-4 中的德文字母 ß (U+00df) try_widen('\xf9'); // ISO-8859-4 中的立陶宛字母 ų (U+0173) std::setlocale(LC_ALL, "lt_LT.utf8"); std::cout << "在立陶宛语 UTF-8 本地环境中:\n"; try_widen('A'); try_widen('\xdf'); try_widen('\xf9'); }
可能的输出:
在立陶宛语 ISO-8859-4 本地环境中: 被加宽为 0x41 被加宽为 0x41 被加宽为 0xdf 被加宽为 0xdf 被加宽为 0xf9 被加宽为 0x173 在立陶宛语 UTF-8 本地环境中: 被加宽为 0x41 被加宽为 0x41 被加宽为 0xdf 加宽失败 被加宽为 0xf9 加宽失败
参阅
若可能,则窄化宽字符为单字节窄字符 (函数) | |
[虚] |
将一个或多个字符从 char 转换到 CharT ( std::ctype<CharT> 的虚受保护成员函数) |