std::btowc
来自cppreference.com
<tbody>
</tbody>
| 在标头 <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> 的虚受保护成员函数)
|
btowc 的 C 文档
| |