std::wbuffer_convert

来自cppreference.com
< cpp‎ | locale
 
 
 
 
在标头 <locale> 定义
template<

    class Codecvt,
    class Elem = wchar_t,
    class Tr = std::char_traits<Elem>

> class wbuffer_convert : public std::basic_streambuf<Elem, Tr>
(C++11 起)
(C++17 中弃用)
(C++26 中移除)

std::wbuffer_convert 是对 std::basic_streambuf<char> 类型的流缓冲的包装器,并给予它 std::basic_streambuf<Elem> 的外观。所有通过 std::wbuffer_convert 进行的 I/O 都会经历刻面 Codecvt 所定义的字符转换。std::wbuffer_convert 假设拥有转换刻面的所有权,而不能使用本地环境所管理的转换刻面。适用于 std::wbuffer_convert 的标准刻面对于 UTF-8/UCS2 和 UTF-8/UCS4 转换是 std::codecvt_utf8,而对于 UTF-8/UTF-16 转换是 std::codecvt_utf8_utf16

此类模板令 std::basic_filebuf 的隐式字符转换功能对任何 std::basic_streambuf 可用。

成员类型

成员类型 定义
state_type Codecvt::state_type

成员函数

构造新的 wbuffer_convert
(公开成员函数)
operator=
复制赋值运算符被弃置
(公开成员函数)
析构 wbuffer_convert 及其转换刻面
(公开成员函数)
返回或替换底层窄流缓冲
(公开成员函数)
返回当前转换状态
(公开成员函数)

参阅

字符转换 本地环境定义的多字节
(UTF-8, GB18030)
UTF-8
UTF-16
UTF-16 mbrtoc16 / c16rtomb(有 C11 的 DR488)

codecvt<char16_t,char,mbstate_t>
codecvt_utf8_utf16<char16_t>
codecvt_utf8_utf16<char32_t>
codecvt_utf8_utf16<wchar_t>

不适用
UCS-2 c16rtomb(无 C11 的 DR488) codecvt_utf8<char16_t> codecvt_utf16<char16_t>
UTF-32

mbrtoc32 / c32rtomb

codecvt<char32_t,char,mbstate_t>
codecvt_utf8<char32_t>

codecvt_utf16<char32_t>

系统宽 wchar_t:

UTF-32 (非 Windows)
UCS2(Windows)

mbsrtowcs / wcsrtombs
use_facet<codecvt
<wchar_t,char,mbstate_t>>(locale)

codecvt_utf8<wchar_t> codecvt_utf16<wchar_t>
(C++11)(C++17 中弃用)(C++26 中移除)
进行宽字符串和字节字符串之间的转换
(类模板)
(C++11)(C++17 中弃用)(C++26 中移除)
在 UTF-8 与 UCS-2/UCS-4 间转换
(类模板)
(C++11)(C++17 中弃用)(C++26 中移除)
在 UTF-8 与 UTF-16 间转换
(类模板)