Funksjonen vsscanf () i C ++ brukes til å lese dataene fra en strengbuffer.
Funksjonen vsscanf () er definert i topptekstfilen.
vsscanf () prototype
int vsscanf (const char * buffer, const char * format, va_list vlist);
Funksjonen vsscanf () leser dataene fra tegnstrengbufferbufferen og lagrer verdiene på de respektive stedene som definert av vlist.
vsscanf () Parametere
- format: peker til en null-avsluttet tegnstreng som spesifiserer hvordan du skal lese inngangen. Den består av formatspesifikatorer som begynner med%.
Formatstrengen har følgende deler:- Ikke tegn mellomrom unntatt% som hver bruker ett identisk tegn fra inngangsstrømmen. Det kan føre til at funksjonen mislykkes hvis neste tegn på strømmen ikke sammenligner like.
- Hvitt mellomromstegn: Alle påfølgende tegn i hvitt mellomrom blir behandlet som ett hvitt mellomromstegn. Videre anses ' n', ' t' og '' som de samme.
- Konverteringsspesifikasjon: Den følger følgende format:
- Innledende% tegn som spesifiserer begynnelsen
- En valgfri * kalt oppdragsdempende karakter. Hvis dette tegnet er tilstede, tildeler vsscanf () ikke resultatet til noe mottaksargument.
- Et valgfritt positivt heltall som spesifiserer maksimal feltbredde. Den angir det maksimale antall tegn som vsscanf () har lov til å konsumere når konverteringen er spesifisert av gjeldende konverteringsspesifikasjon.
- En valgfri lengdemodifikator som angir størrelsen på mottaksargumentet.
- En konverteringsformatspesifikator.
Format Spesifikator Beskrivelse % Matcher bokstavelig% c Matcher et enkelt tegn eller flere tegn. Hvis bredde er definert, samsvarer den nøyaktig med tegn i bredden. s Matcher påfølgende ikke-mellomromstegn. Hvis bredde er definert, samsvarer den nøyaktig med tegn i bredden eller til første hvite mellomrom er funnet. (sett) Matcher en ikke-tom sekvens av tegn fra det gitte settet med tegn. Hvis er tilstede i begynnelsen av settet, samsvarer alle tegnene som ikke er i settet. d Matcher et desimaltall. Jeg Matcher et heltall. o Matcher et usignert oktalt heltall. X eller x Matcher et usignert heksadesimalt heltall. u Matcher et usignert desimaltall. A eller a, E eller e, F eller f, G eller g Matcher et flytende nummer. n Returnerer antall tegn som er lest hittil. s Matcher en implementeringsdefinert tegnsekvens som definerer en peker.
Så det generelle formatet til formatspesifikatoren er:% (*) (bredde) (lengde) spesifikator
- vlist: En liste over argumenter for å motta inngangene.
vsscanf () Returverdi
- Hvis vellykket, returnerer funksjonen vsscanf () antall argumenter som er lest.
- Ved feil returneres EOF.
Eksempel: Hvordan funksjonen vsscanf () fungerer?
#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; )
Når du kjører programmet, vil en mulig utgang være:
Bruce Wayne er Batman.