命名空间
变体
操作

std::ctype<CharT>::widen, do_widen

来自 cppreference.com
< cpp‎ | locale‎ | ctype
 
 
 
 
定义在头文件 <locale>
public:
CharT widen( char c ) const;
(1)
public:
const char* widen( const char* beg, const char* end, CharT* dst ) const;
(2)
protected:
virtual CharT do_widen( char c ) const;
(3)
protected:
virtual const char* do_widen( const char* beg, const char* end, CharT* dst ) const;
(4)
1,2) 公共成员函数,调用最派生类的相应受保护虚拟成员函数 do_widen 重载。重载 (1) 调用 do_widen(c),重载 (2) 调用 do_widen(beg, end, dst).
3) 使用最合理的简单转换,将单字节字符 c 转换为相应的宽字符表示。通常,这仅适用于其多字节编码为单个字节的字符(例如 UTF-8 中的 U+0000-U+007F)。
4) 对于字符数组 [begend) 中的每个字符,将相应的加宽字符写入 dst 指向的字符数组的连续位置。

加宽总是返回一个宽字符,但仅 基本源字符集(直到 C++23)基本字符集(自 C++23) 中的字符保证具有唯一的、定义明确的加宽转换,并且该转换也保证是可逆的(通过 narrow())。实际上,所有其多字节表示形式为单个字节的字符通常都被加宽为其宽字符对应物,而其他可能的单字节值通常被映射到同一个占位符值,通常是 CharT(-1).

加宽,如果成功,将保留 is() 已知的字符分类类别。

内容

[编辑] 参数

c - 要转换的字符
dflt - 如果转换失败,要产生的默认值
beg - 指向要转换的字符数组中第一个字符的指针
end - 指向要转换的字符数组的末尾指针之后的指针
dst - 指向要填充的字符数组的第一个元素的指针

[编辑] 返回值

1,3) 加宽字符。
2,4) end

[编辑] 示例

#include <iostream>
#include <locale>
 
void try_widen(const std::ctype<wchar_t>& f, char c)
{
    wchar_t w = f.widen(c);
    std::cout << "The single-byte character " << +(unsigned char)c
              << " widens to " << +w << '\n';
}
 
int main()
{
    std::locale::global(std::locale("cs_CZ.iso88592"));
    auto& f = std::use_facet<std::ctype<wchar_t>>(std::locale());
    std::cout << std::hex << std::showbase << "In Czech ISO-8859-2 locale:\n";
    try_widen(f, 'a');
    try_widen(f, '\xdf'); // German letter ß (U+00df) in ISO-8859-2
    try_widen(f, '\xec'); // Czech letter ě (U+011b) in ISO-8859-2
 
    std::locale::global(std::locale("cs_CZ.utf8"));
    auto& f2 = std::use_facet<std::ctype<wchar_t>>(std::locale());
    std::cout << "In Czech UTF-8 locale:\n";
    try_widen(f2, 'a');
    try_widen(f2, '\xdf'); 
    try_widen(f2, '\xec'); 
}

可能的输出

In Czech ISO-8859-2 locale:
The single-byte character 0x61 widens to 0x61
The single-byte character 0xdf widens to 0xdf
The single-byte character 0xec widens to 0x11b
In Czech UTF-8 locale:
The single-byte character 0x61 widens to 0x61
The single-byte character 0xdf widens to 0xffffffff
The single-byte character 0xec widens to 0xffffffff

[编辑] 缺陷报告

以下行为改变的缺陷报告被追溯应用于先前发布的 C++ 标准。

DR 应用于 发布的行为 正确的行为
LWG 153 C++98 widen 总是调用重载 (4) 调用相应的重载

[编辑] 另请参阅

调用 do_narrow
(公共成员函数) [编辑]
加宽字符
(std::basic_ios<CharT,Traits> 的公共成员函数) [编辑]
如果可能,将单个字节窄字符加宽为宽字符
(函数) [编辑]