std:: c32rtomb
|
Definiert im Header
<cuchar>
|
||
|
std::
size_t
c32rtomb
(
char
*
s,
char32_t
c32,
std::
mbstate_t
*
ps
)
;
|
(seit C++11) | |
Konvertiert ein UTF-32-Zeichen in seine schmale Multibyte-Darstellung.
Wenn s kein Nullzeiger ist, bestimmt die Funktion die Anzahl der Bytes, die notwendig sind, um die Multibyte-Zeichendarstellung von c32 zu speichern (einschließlich aller Shift-Sequenzen und unter Berücksichtigung des aktuellen Multibyte-Konvertierungszustands * ps ), und speichert die Multibyte-Zeichendarstellung im Zeichenarray, dessen erstes Element durch s gezeigt wird, wobei * ps bei Bedarf aktualisiert wird. Diese Funktion kann maximal MB_CUR_MAX Bytes schreiben.
Wenn
s
ein Nullzeiger ist, entspricht der Aufruf
std
::
c32rtomb
(
buf, U
'
\0
'
, ps
)
für einen internen Puffer
buf
.
Wenn c32 das breite Nullzeichen U ' \0 ' ist, wird ein Nullbyte gespeichert, vorangestellt von jeder Shift-Sequenz, die notwendig ist, um den initialen Shift-Zustand wiederherzustellen, und der Konvertierungszustandsparameter * ps wird aktualisiert, um den initialen Shift-Zustand darzustellen.
Die Multibyte-Kodierung, die von dieser Funktion verwendet wird, wird durch das aktuell aktive C-Locale festgelegt.
Inhaltsverzeichnis |
Parameter
| s | - | Zeiger auf ein schmales Zeichenarray, in dem das Multibyte-Zeichen gespeichert wird |
| c32 | - | das 32-Bit-Zeichen zur Konvertierung |
| ps | - | Zeiger auf das Konvertierungszustandsobjekt, das bei der Interpretation der Multibyte-Zeichenkette verwendet wird |
Rückgabewert
Bei Erfolg gibt die Anzahl der Bytes (einschließlich aller Shift-Sequenzen) zurück, die in das Zeichenarray geschrieben wurden, dessen erstes Element durch s gezeigt wird. Dieser Wert kann 0 sein, z.B. bei der Verarbeitung des ersten char32_t in einer Multi- char32_t -Zeichensequenz (tritt in UTF-32 nicht auf).
Bei Fehler (wenn c32 kein gültiges 32-Bit-Zeichen ist), wird - 1 zurückgegeben, EILSEQ in errno gespeichert und * ps in einem nicht spezifizierten Zustand belassen.
Beispiel
#include <climits> #include <clocale> #include <cuchar> #include <iomanip> #include <iostream> #include <string_view> int main() { std::setlocale(LC_ALL, "en_US.utf8"); std::u32string_view strv = U"zß水🍌"; // or z\u00df\u6c34\U0001F34C std::cout << "Processing " << strv.size() << " UTF-32 code units: [ "; for (char32_t c : strv) std::cout << std::showbase << std::hex << static_cast<int>(c) << ' '; std::cout << "]\n"; std::mbstate_t state{}; char out[MB_LEN_MAX]{}; for (char32_t c : strv) { std::size_t rc = std::c32rtomb(out, c, &state); std::cout << static_cast<int>(c) << " converted to [ "; if (rc != (std::size_t) - 1) for (unsigned char c8 : std::string_view{out, rc}) std::cout << +c8 << ' '; std::cout << "]\n"; } }
Ausgabe:
Processing 4 UTF-32 code units: [ 0x7a 0xdf 0x6c34 0x1f34c ] 0x7a converted to [ 0x7a ] 0xdf converted to [ 0xc3 0x9f ] 0x6c34 converted to [ 0xe6 0xb0 0xb4 ] 0x1f34c converted to [ 0xf0 0x9f 0x8d 0x8c ]
Siehe auch
|
(C++11)
|
wandelt ein schmales Multibyte-Zeichen in UTF-32-Kodierung um
(Funktion) |
|
[virtual]
|
wandelt eine Zeichenkette von
InternT
zu
ExternT
um, z.B. beim Schreiben in eine Datei
(virtuelle geschützte Elementfunktion von
std::codecvt<InternT,ExternT,StateT>
)
|
|
C-Dokumentation
für
c32rtomb
|
|