std::wstring_convert<Codecvt,Elem,Wide_alloc,Byte_alloc>:: wstring_convert
From cppreference.net
<
cpp
|
locale
|
wstring convert
|
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.
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
Exécuter ce code
#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 |