C ++ swscanf () - C ++ standaardbibliotheek

De functie swscanf () in C ++ leest brede tekens uit een brede tekenreeksbuffer.

De functie swscanf () is gedefinieerd in het header-bestand.

swscanf () prototype

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

De functie swscanf () leest de gegevens uit de buffer en slaat de waarden op in de respectievelijke variabelen.

swscanf () Parameters

  • buffer: Pointer naar de brede tekenreeksbuffer om de gegevens van te lezen.
  • format: Pointer naar een tekenreeks met een null-einde die aangeeft hoe de invoer moet worden gelezen. Het bestaat uit formaatspecificaties die beginnen met%.
    De format string heeft de volgende onderdelen:
    • Niet-witruimte-tekens behalve%, die elk één identiek teken uit de invoerstroom verbruiken. Het kan ervoor zorgen dat de functie mislukt als het volgende personage in de stream niet gelijk is.
    • Witruimteteken: Alle opeenvolgende witruimtetekens worden behandeld als een enkel witruimteteken. Verder worden ' n', ' t' en '' als hetzelfde beschouwd.
    • Conversiespecificatie: het volgt het volgende formaat:
      • Initieel% -teken dat het begin aangeeft
      • Een optioneel * genaamd toewijzingsonderdrukkend teken. Als dit teken aanwezig is, wijst swscanf () het resultaat niet toe aan een ontvangend argument.
      • Een optioneel positief geheel getal dat de maximale veldbreedte aangeeft. Het specificeert het maximale aantal tekens dat swscanf () mag verbruiken bij het uitvoeren van de conversie gespecificeerd door de huidige conversiespecificatie.
      • Een optionele lengtemodificator die de grootte van het ontvangende argument specificeert.
      • Een specificatie voor het conversieformaat.
    Formaatspecificaties
    Formaatspecificatie Omschrijving
    % Komt overeen met de letterlijke%
    c Komt overeen met een enkel teken of meerdere tekens. Als breedte is gedefinieerd, komt overeen met exact breedtetekens.
    s Komt overeen met opeenvolgende niet-witruimte-tekens. Als breedte is gedefinieerd, komt overeen met exact breedtetekens of totdat de eerste witruimte is gevonden.
    (set) Komt overeen met een niet-lege tekenreeks uit de opgegeven reeks tekens. Als aanwezig is aan het begin van de set, komen alle karakters die niet in de set zitten overeen.
    d Komt overeen met een decimaal geheel getal.
    ik Komt overeen met een geheel getal.
    O Komt overeen met een octaal geheel getal zonder teken.
    X of x Komt overeen met een niet-ondertekend hexadecimaal geheel getal.
    u Komt overeen met een decimaal geheel getal zonder teken.
    A of a, E of e, F of f, G of g Komt overeen met een getal met drijvende komma.
    n Retourneert het aantal tot dusver gelezen tekens.
    p Komt overeen met een door de implementatie gedefinieerde tekenreeks die een pointer definieert.

    Dus het algemene formaat van de formaatspecificatie is:
     % (*) (breedte) (lengte) specificatie
  • …: Andere aanvullende argumenten voor het ontvangen van gegevens. Ze komen voor in een reeks volgens de formaatspecificatie.

swscanf () Retourwaarde

  • De functie swscanf () retourneert het aantal ontvangen argumenten dat succesvol is toegewezen.
  • Als er een fout optreedt voordat het eerste ontvangende argument is toegewezen, wordt EOF geretourneerd.

Voorbeeld: hoe werkt de functie 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; )

Wanneer u het programma uitvoert, is een mogelijke uitvoer:

 θ is Theta

Interessante artikelen...