Funksjonen swscanf () i C ++ leser stort tegn fra bred strengbuffer.
Funksjonen swscanf () er definert i topptekstfilen.
swscanf () prototype
int swscanf (const wchar_t * buffer, const wchar_t * format,…);
Funksjonen swscanf () leser dataene fra bufferen og lagrer verdiene i de respektive variablene.
swscanf () Parametere
- buffer: peker til den brede strengbufferen for å lese dataene fra.
- 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 ikke swscanf () resultatet til noe mottaksargument.
- Et valgfritt positivt heltall som spesifiserer maksimal feltbredde. Den spesifiserer maksimalt antall tegn som swscanf () har lov til å konsumere når konverteringen er spesifisert i den gjeldende konverteringsspesifikasjonen.
- 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
- …: Andre tilleggsargumenter for mottak av data. De forekommer i en sekvens i henhold til formatet.
swscanf () Returverdi
- Funksjonen swscanf () returnerer antall mottaksargumenter som er tilordnet.
- Hvis feil oppstår før det første mottaksargumentet ble tildelt, returneres EOF .
Eksempel: Hvordan fungerer 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; )
Når du kjører programmet, vil en mulig utgang være:
θ er Theta