C ++ fwscanf () - C ++ standaardbibliotheek

De functie fwscanf () in C ++ leest brede tekens uit de bestandsstroom.

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

fwscanf () prototype

 int fwscanf (FILE * stream, const wchar_t * format, …);

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

fwscanf () Parameters

  • stream: De invoerbestandsstream waarvan de gegevens moeten worden gelezen.
  • 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 fwscanf () het resultaat niet toe aan een ontvangend argument.
      • Een optioneel positief geheel getal dat de maximale veldbreedte aangeeft. Het specificeert het maximum aantal karakters dat fwscanf () 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.

fwscanf () Retourwaarde

  • De functie fwscanf () 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 fwscanf ()?

 #include #include #include #include int main() ( FILE *fp = fopen("example.txt","w+"); wchar_t str(10), ch; setlocale(LC_ALL, "en_US.UTF-8"); fwprintf(fp, L"%ls %lc", L"Summation", L'u2211'); fwprintf(fp, L"%ls %lc", L"Integral", L'u222b'); rewind(fp); while((fwscanf(fp, L"%ls %lc", str, &ch))!=EOF) ( wprintf(L"%lc is %ls", ch, str); ) fclose(fp); return 0; )

Wanneer u het programma uitvoert, is een mogelijke uitvoer:

 ∑ is sommatie ∫ is integraal

Interessante artikelen...