C ++ swscanf () - C ++ Standardbibliothek

Die Funktion swscanf () in C ++ liest breite Zeichen aus breiten Zeichenfolgenpuffern.

Die Funktion swscanf () ist in der Header-Datei definiert.

swscanf () Prototyp

 int swscanf (const wchar_t * buffer, const wchar_t * format,…);

Die Funktion swscanf () liest die Daten aus dem Puffer und speichert die Werte in den jeweiligen Variablen.

swscanf () Parameter

  • buffer: Zeiger auf den breiten Zeichenfolgenpuffer, aus dem die Daten gelesen werden sollen.
  • Format: Zeiger auf eine nullterminierte Zeichenfolge, die angibt, wie die Eingabe gelesen werden soll. Es besteht aus Formatbezeichnern, die mit% beginnen.
    Die Formatzeichenfolge besteht aus folgenden Teilen:
    • Nicht-Leerzeichen, außer%, von denen jedes ein identisches Zeichen aus dem Eingabestream verbraucht. Dies kann dazu führen, dass die Funktion fehlschlägt, wenn das nächste Zeichen im Stream nicht gleich ist.
    • Leerzeichen: Alle aufeinanderfolgenden Leerzeichen werden als einzelne Leerzeichen behandelt. Ferner werden ' n', ' t' und '' als gleich angesehen.
    • Konvertierungsspezifikation: Es folgt dem folgenden Format:
      • Anfangszeichen%, das den Anfang angibt
      • Ein optionales *, das als zuweisungsunterdrückendes Zeichen bezeichnet wird. Wenn dieses Zeichen vorhanden ist, weist swscanf () das Ergebnis keinem empfangenden Argument zu.
      • Eine optionale positive Ganzzahl, die die maximale Feldbreite angibt. Es gibt die maximale Anzahl von Zeichen an, die swscanf () bei der in der aktuellen Konvertierungsspezifikation angegebenen Konvertierung verwenden darf.
      • Ein optionaler Längenmodifikator, der die Größe des empfangenden Arguments angibt.
      • Ein Bezeichner für das Konvertierungsformat.
    Formatbezeichner
    Formatbezeichner Beschreibung
    %. Entspricht dem Literal%
    c Entspricht einem einzelnen Zeichen oder mehreren Zeichen. Wenn width definiert ist, entspricht dies genau den Zeichen für die Breite.
    s Entspricht aufeinanderfolgenden Nicht-Leerzeichen. Wenn width definiert ist, entspricht dies genau den Zeichen für die Breite oder bis das erste Leerzeichen gefunden wird.
    (einstellen) Entspricht einer nicht leeren Zeichenfolge aus dem angegebenen Zeichensatz. Wenn am Anfang des Satzes vorhanden ist, werden alle Zeichen, die nicht im Satz enthalten sind, abgeglichen.
    d Entspricht einer Dezimalzahl.
    ich Entspricht einer Ganzzahl.
    Ö Entspricht einer vorzeichenlosen oktalen Ganzzahl.
    X oder x Entspricht einer vorzeichenlosen hexadezimalen Ganzzahl.
    u Entspricht einer vorzeichenlosen Dezimalzahl.
    A oder a, E oder e, F oder f, G oder g Entspricht einer Gleitkommazahl.
    n Gibt die Anzahl der bisher gelesenen Zeichen zurück.
    p Entspricht einer implementierungsdefinierten Zeichenfolge, die einen Zeiger definiert.

    Das allgemeine Format des Formatbezeichners lautet also:
     % (*) (Breite) (Länge) Spezifizierer
  • …: Weitere zusätzliche Argumente für den Datenempfang. Sie treten in einer Reihenfolge gemäß dem Formatbezeichner auf.

swscanf () Rückgabewert

  • Die Funktion swscanf () gibt die Anzahl der erfolgreich zugewiesenen Empfangsargumente zurück.
  • Wenn ein Fehler auftritt, bevor das erste empfangende Argument zugewiesen wurde, wird EOF zurückgegeben.

Beispiel: Wie funktioniert die Funktion swscanf ()?

 #include #include int main() ( wchar_t buffer(100) = L"Theta u03b8"; wchar_t symbol, desc(10); setlocale(LC_ALL, "en_US.UTF-8"); swscanf(buffer, L"%ls %lc", desc, &symbol); wprintf(L"%lc is %ls", symbol, desc); return 0; )

Wenn Sie das Programm ausführen, ist eine mögliche Ausgabe:

 θ ist Theta

Interessante Beiträge...