命名空间
变体
操作

std::wbuffer_convert

来自 cppreference.cn
< 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_convertstd::basic_streambuf<char> 类型流缓冲区的包装器,使其外观类似于 std::basic_streambuf<Elem>。 所有通过 std::wbuffer_convert 执行的 I/O 都将根据 facet Codecvt 的定义进行字符转换。 std::wbuffer_convert 假定拥有转换 facet 的所有权,并且不能使用由区域设置管理的 facet。

适用于 std::wbuffer_convert 的标准 facet 是 std::codecvt_utf8,用于 UTF-8/UCS-2 和 UTF-8/UCS-4 转换,以及 std::codecvt_utf8_utf16,用于 UTF-8/UTF-16 转换。

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

内容

[编辑] 成员类型

类型 定义
state_type Codecvt::state_type

[编辑] 数据成员

成员 描述
std::streambuf* bufptr 指向底层字节流缓冲区的指针
(仅用于说明的成员对象*)
Codecvt* cvtptr 指向已分配的转换对象的指针
(仅用于说明的成员对象*)
state_type cvtstate 转换状态对象
(仅用于说明的成员对象*)

[编辑] 成员函数

构造新的 wbuffer_convert
(公共成员函数) [编辑]
operator=
复制赋值运算符已删除
(公共成员函数)
析构 wbuffer_convert 及其转换 facet
(公共成员函数) [编辑]
返回或替换底层窄流缓冲区
(公共成员函数) [编辑]
返回当前转换状态
(公共成员函数) [编辑]

[编辑] 参见

字符
转换
区域设置定义的多字节
(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)
UCS-2 (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 之间转换
(类模板) [编辑]