std::ctype<CharT>::widen, do_widen
来自cppreference.com
在标头 <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) 对字符数组
[
beg,
end)
中每个字符,写入对应的加宽字符到 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 << "单字节字符 " << +(unsigned char)c << " 加宽为 " << +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 << "在捷克语 ISO-8859-2 本地环境下:\n"; try_widen(f, 'a'); try_widen(f, '\xdf'); // ISO-8859-2 中的德文字母 ß (U+00df) try_widen(f, '\xec'); // ISO-8859-2 中的捷克文字母 ě (U+011b) std::locale::global(std::locale("cs_CZ.utf8")); auto& f2 = std::use_facet<std::ctype<wchar_t>>(std::locale()); std::cout << "在捷克语 UTF-8 本地环境下:\n"; try_widen(f2, 'a'); try_widen(f2, '\xdf'); try_widen(f2, '\xec'); }
输出:
在捷克语 ISO-8859-2 本地环境下: 单字节字符 0x61 加宽为 to 0x61 单字节字符 0xdf 加宽为 to 0xdf 单字节字符 0xec 加宽为 to 0x11b 在捷克语 UTF-8 本地环境下: 单字节字符 0x61 加宽为 to 0x61 单字节字符 0xdf 加宽为 to 0xffffffff 单字节字符 0xec 加宽为 to 0xffffffff
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 153 | C++98 | widen 只会调用重载 (4)
|
会调用对应重载 |
参阅
调用 do_narrow (公开成员函数) | |
拓宽字符 ( std::basic_ios<CharT,Traits> 的公开成员函数) | |
若可能,则加宽单字节窄字符为宽字符 (函数) |