mbrtowc
| Definiert in Header <wchar.h> |
||
| (seit C95) | ||
| (seit C99) | ||
Konvertiert ein schmalen Multibyte-Zeichen in seine Wide-Character-Repräsentation.
Wenn s kein Nullzeiger ist, werden höchstens n Bytes der schmalen Multibyte-Zeichenzeichenkette untersucht, beginnend mit dem Byte, auf das s zeigt, um die Anzahl der Bytes zu ermitteln, die zur Vervollständigung des nächsten Multibyte-Zeichens erforderlich sind (einschließlich aller Umschaltsequenzen und unter Berücksichtigung des aktuellen Multibyte-Konvertierungszustands *ps). Wenn die Funktion feststellt, dass das nächste Multibyte-Zeichen in s vollständig und gültig ist, wird es in das entsprechende Wide-Character konvertiert und in *pwc gespeichert (wenn pwc nicht null ist).
Wenn s ein Nullzeiger ist, werden die Werte von n und pwc ignoriert und der Aufruf ist äquivalent zu mbrtowc(NULL, "", 1, ps).
Wenn das erzeugte Wide-Character das Nullzeichen ist, ist der in *ps gespeicherte Konvertierungszustand der anfängliche Umschaltzustand.
Wenn das Makro __STDC_ISO_10646__ definiert ist, sind die Werte des Typs wchar_t identisch mit den Kurzbezeichnern der Zeichen des erforderlichen Unicode-Zeichensatzes (typischerweise UTF-32-Kodierung); andernfalls ist dies implementierungsabhängig. In jedem Fall wird die von dieser Funktion verwendete Multibyte-Zeichenkodierung durch die aktuell aktive C-Locale festgelegt.
Inhalt |
[bearbeiten] Parameter
| pwc | - | Zeiger auf die Stelle, an der das resultierende Wide-Character geschrieben werden soll |
| s | - | Zeiger auf den Mehrbyte-Zeichenstring, der als Eingabe verwendet wird |
| n | - | Grenze für die Anzahl der Bytes in s, die untersucht werden können |
| ps | - | Zeiger auf den Konvertierungszustand, der bei der Interpretation der schmalen Multibyte-Zeichenzeichenkette verwendet wird |
[bearbeiten] Rückgabewert
Das erste der folgenden zutreffenden Elemente
- 0, wenn das aus
skonvertierte Zeichen (und, falls nicht null, in pwc gespeichert) das Nullzeichen war - die Anzahl der Bytes [1...n] des erfolgreich aus
skonvertierten Multibyte-Zeichens - (size_t)-2, wenn die nächsten
nBytes ein unvollständiges, aber bisher gültiges Multibyte-Zeichen darstellen. Es wird nichts in *pwc geschrieben. - (size_t)-1, wenn ein Kodierungsfehler auftritt. Es wird nichts in
*pwcgeschrieben, der Wert EILSEQ wird in errno gespeichert und der Wert von *ps bleibt undefiniert.
[bearbeiten] Beispiel
#include <stdio.h> #include <locale.h> #include <string.h> #include <wchar.h> int main(void) { setlocale(LC_ALL, "en_US.utf8"); mbstate_t state; memset(&state, 0, sizeof state); char in[] = u8"z\u00df\u6c34\U0001F34C"; // or u8"zß水🍌" size_t in_sz = sizeof in / sizeof *in; printf("Processing %zu UTF-8 code units: [ ", in_sz); for(size_t n = 0; n < in_sz; ++n) printf("%#x ", (unsigned char)in[n]); puts("]"); wchar_t out[in_sz]; char *p_in = in, *end = in + in_sz; wchar_t *p_out = out; int rc; while((rc = mbrtowc(p_out, p_in, end - p_in, &state)) > 0) { p_in += rc; p_out += 1; } size_t out_sz = p_out - out + 1; printf("into %zu wchar_t units: [ ", out_sz); for(size_t x = 0; x < out_sz; ++x) printf("%#x ", out[x]); puts("]"); }
Ausgabe
Processing 11 UTF-8 code units: [ 0x7a 0xc3 0x9f 0xe6 0xb0 0xb4 0xf0 0x9f 0x8d 0x8c 0 ] into 5 wchar_t units: [ 0x7a 0xdf 0x6c34 0x1f34c 0 ]
[bearbeiten] Referenzen
- C11-Standard (ISO/IEC 9899:2011)
- 7.29.6.3.2 Die Funktion mbrtowc (S. 443)
- C99-Standard (ISO/IEC 9899:1999)
- 7.24.6.3.2 Die Funktion mbrtowc (S. 389)
[bearbeiten] Siehe auch
| konvertiert das nächste Multibyte-Zeichen in ein Wide-Zeichen (Funktion) | |
| (C95)(C11) |
konvertiert ein Wide-Zeichen in seine Multibyte-Darstellung, gegeben den Zustand (Funktion) |
| C++ Dokumentation für mbrtowc
| |