C ++ swscanf () - C ++ Standardbibliotek

Funktionen swscanf () i C ++ læser bred karakter fra bred strengbuffer.

Funktionen swscanf () er defineret i headerfilen.

swscanf () prototype

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

Funktionen swscanf () læser data fra buffer og gemmer værdierne i de respektive variabler.

swscanf () Parametre

  • buffer: Markør til den brede strengbuffer til at læse dataene fra.
  • format: Markør til en null-termineret tegnstreng, der specificerer, hvordan input skal læses. Den består af formatspecifikationer, der starter med%.
    Formatstrengen har følgende dele:
    • Ikke-mellemrumstegn undtagen%, som hver bruger et identisk tegn fra inputstrømmen. Det kan få funktionen til at mislykkes, hvis det næste tegn på streamen ikke sammenligner det samme.
    • Hvidt mellemrumstegn: Alle på hinanden følgende mellemrumstegn behandles som et enkelt mellemrumstegn. Yderligere betragtes ' n', ' t' og '' som de samme.
    • Konverteringsspecifikation: Den følger følgende format:
      • Indledende% tegn, der angiver begyndelsen
      • En valgfri * kaldet tildelingsundertrykkende karakter. Hvis dette tegn er til stede, tildeler swscanf () ikke resultatet til noget modtagende argument.
      • Et valgfrit positivt heltal, der angiver den maksimale feltbredde. Den specificerer det maksimale antal tegn, som swscanf () har tilladelse til at forbruge, når den konvertering er specificeret af den aktuelle konverteringsspecifikation.
      • En valgfri længdemodifikator, der angiver størrelsen på det modtagende argument.
      • En konverteringsformat specificerer.
    Formatspecifikatorer
    Format Specifier Beskrivelse
    % Matcher den bogstavelige%
    c Matcher et enkelt tegn eller flere tegn. Hvis bredde er defineret, matcher den nøjagtigt bredde.
    s Matcher på hinanden følgende ikke-mellemrumstegn. Hvis bredde er defineret, matcher den nøjagtigt bredde tegn, eller indtil første hvide mellemrum er fundet.
    (sæt) Matcher en ikke-tom række af tegn fra det givne sæt tegn. Hvis er til stede i begyndelsen af ​​sættet, matches alle de tegn, der ikke er i sættet.
    d Matcher et decimaltal.
    jeg Matcher et heltal.
    o Matcher et usigneret oktalt heltal.
    X eller x Matcher et usigneret hexadecimalt heltal.
    u Matcher et usigneret decimaltal.
    A eller a, E eller e, F eller f, G eller g Matcher et flydende nummer.
    n Returnerer antallet af læste tegn indtil videre.
    s Matcher en implementeringsdefineret tegnsekvens, der definerer en markør.

    Så det generelle format for formatspecifikator er:
     % (*) (bredde) (længde) specificator
  • …: Andre yderligere argumenter for modtagelse af data. De forekommer i en sekvens i henhold til formatspecifikatoren.

swscanf () Returværdi

  • Funktionen swscanf () returnerer antallet af modtagende argumenter, der er tildelt med succes.
  • Hvis der opstår fejl, før det første modtagelsesargument blev tildelt, returneres EOF .

Eksempel: Hvordan fungerer swscanf () -funktionen?

 #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 kører programmet, vil en mulig output være:

 θ er Theta

Interessante artikler...