C ++ wscanf () - C ++ Standardbibliothek

Die Funktion wscanf () in C ++ liest breite Zeichen aus stdin.

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

wscanf () Prototyp

 int wscanf (const char * format,…);

Die Funktion wscanf () liest die Daten aus stdin und speichert die Werte in den jeweiligen Variablen.

wscanf () Parameter

  • 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 wscanf () das Ergebnis keinem empfangenden Argument zu.
      • Eine optionale positive Ganzzahl, die die maximale Feldbreite angibt. Es gibt die maximale Anzahl von Zeichen an, die wscanf () 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.

wscanf () Rückgabewert

  • Die Funktion wscanf () 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 wscanf ()?

 #include #include #include #include using namespace std; int main() ( wchar_t hebrew_str() = L"u05D0 u05D1 u05E1 u05D3 u05EA"; wchar_t ch; setlocale(LC_ALL, "en_US.UTF-8"); wprintf(L"Enter a wide character: "); wscanf(L"%lc",&ch); if (iswalnum(ch)) wcout << ch << L" is alphanumeric." << endl; else wcout << ch << L" is not alphanumeric." << endl; return 0; )

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

 Geben Sie ein breites Zeichen ein: ∭ ∭ ist nicht alphanumerisch.

Interessante Beiträge...