Namespaces
Variants

std::wstring_convert<Codecvt,Elem,Wide_alloc,Byte_alloc>:: wstring_convert

From cppreference.net
wstring_convert ( ) : wstring_convert ( new Codecvt ) { }
(1)
explicit wstring_convert ( Codecvt * pcvt ) ;
(2)
wstring_convert ( Codecvt * pcvt, state_type state ) ;
(3)
explicit wstring_convert ( const byte_string & byte_err,
const wide_string & wide_err = wide_string ( ) ) ;
(4)
wstring_convert ( const std:: wstring_convert & ) = delete ;
(5) (depuis C++14)
Surcharge Membres de données
byte_err_string wide_err_string cvtptr cvtstate cvtcount
(1) initialisé par défaut new Codecvt initialisé par défaut non initialisé
(2) pcvt
(3) state
(4) byte_err wide_err new Codecvt state_type ( )
2,3) Si pcvt est un pointeur nul, le comportement est indéfini.
5) Le constructeur de copie est supprimé, wstring_convert n'est pas CopyConstructible .

Paramètres

pcvt - pointeur vers la facette de conversion
state - valeur initiale de l'état de décalage de conversion
byte_err - chaîne étroite à afficher en cas d'erreurs
wide_err - chaîne large à afficher en cas d'erreurs

Exemple

#include <codecvt>
#include <locale>
#include <utility>
// utilitaire pour adapter les facets liés aux locales pour la conversion wstring/wbuffer
template<class Facet>
struct deletable_facet : Facet
{
    using Facet::Facet; // hériter des constructeurs
    ~deletable_facet() {}
};
int main()
{
    // Conversion UTF-16le / UCS4
    std::wstring_convert
        <std::codecvt_utf16<char32_t, 0x10ffff, std::little_endian>> u16to32;
    // Conversion UTF-8 / chaîne large avec messages personnalisés
    std::wstring_convert<std::codecvt_utf8<wchar_t>> u8towide("Error!", L"Error!");
    // Facet de conversion GB18030 / chaîne large
    using F = deletable_facet<std::codecvt_byname<wchar_t, char, std::mbstate_t>>;
    std::wstring_convert<F> gbtowide(new F("zh_CN.gb18030"));
}

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement publié Comportement correct
LWG 2175 C++11 pcvt pouvait être un pointeur nul le comportement est indéfini dans ce cas
LWG 2176 C++11 les constructeurs acceptant un seul argument étaient implicites rendus explicites
P0935R0 C++11 le constructeur par défaut était explicite rendu implicite