std::wstring_convert::wstring_convert

来自cppreference.com
explicit wstring_convert( Codecvt* pcvt = new Codecvt );
(1)
wstring_convert( Codecvt* pcvt, state_type state);
(2)
explicit wstring_convert( const byte_string& byte_err,
                          const wide_string& wide_err = wide_string() );
(3)
wstring_convert(const std::wstring_convert&) = delete;
(4) (C++14 起)
1) 以指定的转换平面,用初始迁移状态和错误字符串的默认构造值构造 wstring_convert 对象。
2) 以指定的转换平面和指定的初始迁移状态,用默认构造的错误字符串值构造 wstring_convert 对象。
3) 以指定的错误字符串,以 new Codecvt 为转换平面并以 state_type 的默认构造值为初始状态构造 wstring_convert 对象。
4) 复制构造函数被删除, wstring_convert 非可复制构造 (CopyConstructible) 。

[编辑] 参数

pcvt - 指向 Codecvt 类型转换平面的指针(若此指针为空则行为未定义)
state - 转换迁移状态的初始值
byte_err - 错误时显示的窄字符串
wide_err - 错误时显示的宽字符串

[编辑] 示例

#include <locale>
#include <utility>
#include <codecvt>
 
// 为 wstring/wbuffer convert 适配绑定本地环境的平面的工具包装器
template<class Facet>
struct deletable_facet : Facet
{
    using Facet::Facet; // 继承构造函数
    ~deletable_facet() {}
};
 
int main()
{
    // UTF-16le / UCS4 转换
    std::wstring_convert<
         std::codecvt_utf16<char32_t, 0x10ffff, std::little_endian>
    > u16to32;
 
    // UTF-8 / 宽字符串转换,带定制消息
    std::wstring_convert<std::codecvt_utf8<wchar_t>> u8towide("Error!", L"Error!");
 
    // GB18030 / 宽字符串转换平面
    typedef deletable_facet<std::codecvt_byname<wchar_t, char, std::mbstate_t>> F;
    std::wstring_convert<F> gbtowide(new F("zh_CN.gb18030"));
}