Die Funktion vsscanf () in C ++ wird verwendet, um die Daten aus einem Zeichenfolgenpuffer zu lesen.
Die Funktion vsscanf () ist in der Header-Datei definiert.
vsscanf () Prototyp
int vsscanf (const char * buffer, const char * format, va_list vlist);
Die Funktion vsscanf () liest die Daten aus dem Zeichenfolgenpufferpuffer und speichert die Werte an den jeweiligen durch vlist definierten Speicherorten.
vsscanf () 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 vsscanf () das Ergebnis keinem empfangenden Argument zu.
- Eine optionale positive Ganzzahl, die die maximale Feldbreite angibt. Es gibt die maximale Anzahl von Zeichen an, die vsscanf () 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 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
- vlist: Eine Liste von Argumenten für den Empfang der Eingaben.
vsscanf () Rückgabewert
- Bei Erfolg gibt die Funktion vsscanf () die Anzahl der erfolgreich gelesenen Argumente zurück.
- Bei einem Fehler wird EOF zurückgegeben.
Beispiel: Wie funktioniert die Funktion vsscanf ()?
#include #include void read(const char* buf, const char * format,… ) ( va_list args; va_start (args, format); vsscanf (buf, format, args); va_end (args); ) int main () ( char buffer(100) = "Bruce Wayne Batman"; char fname(20), lname(20), superhero(20); read(buffer, "%s %s %s", fname, lname, superhero); printf("%s %s is %s.", fname, lname, superhero); return 0; )
Wenn Sie das Programm ausführen, ist eine mögliche Ausgabe:
Bruce Wayne ist Batman.