命名空间
变体
操作

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 的标准面是 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 及其转换面
(公有成员函数) [编辑]
返回或替换底层的窄流缓冲区
(公有成员函数) [编辑]
返回当前转换状态
(公有成员函数) [编辑]

[编辑] 另请参阅

字符
转换
语言环境定义的多字节
(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>

N/A
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 之间转换
(类模板) [编辑]