std::btowc

来自cppreference.com
< cpp‎ | string‎ | multibyte
在标头 <cwchar> 定义
std::wint_t btowc( int c );

加宽单字节字符 c 为其宽字符等价物。

大多数多字节字符编码用单字节码表示来自 ASCII 字符集的字符。此函数可用于转换这种字符为 wchar_t

参数

c - 要加宽的单字节字符

返回值

cEOF 则为 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> 的虚受保护成员函数)