std::ctype<CharT>::widen, do_widen
| Definiert in Header <locale> |
||
| public: CharT widen( char c ) const; |
(1) | |
| public: const char* widen( const char* beg, const char* end, CharT* dst ) const; |
(2) | |
| protected: virtual CharT do_widen( char c ) const; |
(3) | |
| protected: virtual const char* do_widen( const char* beg, const char* end, CharT* dst ) const; |
(4) | |
do_widen-Überladung der am weitesten abgeleiteten Klasse auf. Überladung (1) ruft do_widen(c) auf, Überladung (2) ruft do_widen(beg, end, dst) auf.[beg, end) wird das entsprechende erweiterte Zeichen in die aufeinanderfolgenden Positionen im von dst zeigenden Zeichen-Array geschrieben.Widening gibt immer ein Wide Character zurück, aber nur für Zeichen aus dem grundlegenden Quellzeichenset(bis C++23)grundlegenden Zeichensatz(seit C++23) ist garantiert, dass sie eine eindeutige, wohldefinierte und auch durch narrow() umkehrbare Erweiterungstransformation haben. In der Praxis werden alle Zeichen, deren Multibyte-Darstellung ein einzelnes Byte ist, normalerweise in ihre Wide-Character-Gegenstücke erweitert, und die übrigen möglichen Ein-Byte-Werte werden normalerweise auf denselben Platzhalterwert abgebildet, typischerweise CharT(-1).
Widening bewahrt, wenn erfolgreich, alle Zeichenklassifizierungs-Kategorien, die für is() bekannt sind.
Inhalt |
[bearbeiten] Parameter
| c | - | zu konvertierendes Zeichen |
| dflt | - | Standardwert, der zurückgegeben wird, wenn die Konvertierung fehlschlägt |
| beg | - | Zeiger auf das erste Zeichen in einem Array von Zeichen, das konvertiert werden soll |
| end | - | Zeiger auf die Position nach dem letzten Zeichen im Array von Zeichen, das konvertiert werden soll |
| dst | - | Zeiger auf das erste Element des Arrays von Zeichen, die gefüllt werden sollen |
[bearbeiten] Rückgabewert
[bearbeiten] Beispiel
#include <iostream> #include <locale> void try_widen(const std::ctype<wchar_t>& f, char c) { wchar_t w = f.widen(c); std::cout << "The single-byte character " << +(unsigned char)c << " widens to " << +w << '\n'; } int main() { std::locale::global(std::locale("cs_CZ.iso88592")); auto& f = std::use_facet<std::ctype<wchar_t>>(std::locale()); std::cout << std::hex << std::showbase << "In Czech ISO-8859-2 locale:\n"; try_widen(f, 'a'); try_widen(f, '\xdf'); // German letter ß (U+00df) in ISO-8859-2 try_widen(f, '\xec'); // Czech letter ě (U+011b) in ISO-8859-2 std::locale::global(std::locale("cs_CZ.utf8")); auto& f2 = std::use_facet<std::ctype<wchar_t>>(std::locale()); std::cout << "In Czech UTF-8 locale:\n"; try_widen(f2, 'a'); try_widen(f2, '\xdf'); try_widen(f2, '\xec'); }
Mögliche Ausgabe
In Czech ISO-8859-2 locale: The single-byte character 0x61 widens to 0x61 The single-byte character 0xdf widens to 0xdf The single-byte character 0xec widens to 0x11b In Czech UTF-8 locale: The single-byte character 0x61 widens to 0x61 The single-byte character 0xdf widens to 0xffffffff The single-byte character 0xec widens to 0xffffffff
[bearbeiten] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 153 | C++98 | widen rief immer Überladung (4) auf |
ruft die entsprechende Überladung auf |
[bearbeiten] Siehe auch
ruft do_narrow auf(öffentliche Member-Funktion) | |
| erweitert Zeichen (public member function of std::basic_ios<CharT,Traits>) | |
| erweitert ein ein Byte breites schmales Zeichen zu einem Wide-Zeichen, falls möglich (Funktion) |