C ++ wscanf () - C ++ standaardbibliotheek

De functie wscanf () in C ++ leest brede tekens uit stdin.

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

wscanf () prototype

 int wscanf (const char * formaat, …);

De functie wscanf () leest de gegevens van stdin en slaat de waarden op in de respectievelijke variabelen.

wscanf () Parameters

  • 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 wscanf () 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 wscanf () mag verbruiken bij het uitvoeren van de conversie die is 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.

wscanf () Retourwaarde

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

 #include #include #include #include using namespace std; int main() ( wchar_t hebrew_str() = L"u05D0 u05D1 u05E1 u05D3 u05EA"; wchar_t ch; setlocale(LC_ALL, "en_US.UTF-8"); wprintf(L"Enter a wide character: "); wscanf(L"%lc",&ch); if (iswalnum(ch)) wcout << ch << L" is alphanumeric." << endl; else wcout << ch << L" is not alphanumeric." << endl; return 0; )

Wanneer u het programma uitvoert, is een mogelijke uitvoer:

 Voer een breed teken in: ∭ ∭ is niet alfanumeriek.

Interessante artikelen...