C ++ vwscanf () - C ++ - vakiokirjasto

Toimintoa vwscanf () C ++: ssa käytetään lukemaan leveä merkkijono stdinistä.

Funktio vwscanf () määritetään otsikkotiedostossa.

vwscanf () -prototyyppi

 int vwscanf (const wchar_t * -muoto, va_list vlist);

Vwscanf () -toiminto lukee tiedot stdinistä ja tallentaa arvot vastaaviin paikkoihin, kuten vlist määrittelee.

vwscanf () -parametrit

  • muoto: Osoitin nollapäätteiseen laajaan merkkijonoon, joka määrittää, miten syötettä luetaan. Se koostuu muotomäärittimistä, jotka alkavat%: lla.
    Formaatin merkkijonossa on seuraavat osat:
    • Muut kuin välilyönnit, paitsi%, joista kukin kuluttaa yhden identtisen merkin syöttövirrasta. Se voi aiheuttaa funktion epäonnistumisen, jos virran seuraava merkki ei ole yhtä suuri.
    • Välilyönti-merkki: Kaikki peräkkäiset tyhjät-merkit käsitellään yhtenä tyhjänä -merkkinä. Lisäksi ' n', ' t' ja '' pidetään samoina.
    • Muunnosmäärittely: Se noudattaa seuraavaa muotoa:
      • Alkuperäinen% merkki, joka määrittää alun
      • Valinnainen * nimeltään tehtävää tukahduttava merkki. Jos tämä merkki on läsnä, vwscanf () ei määritä tulosta mihinkään vastaanottavaan argumenttiin.
      • Valinnainen positiivinen kokonaisluku, joka määrittää kentän enimmäisleveyden. Se määrittää merkkien enimmäismäärän, jonka vwscanf () saa kuluttaa tehdessään nykyisen muunnosmäärityksen mukaisen muunnoksen.
      • Valinnainen pituusmuunnin, joka määrittää vastaanottavan argumentin koon.
      • Muunnosmuodon määrittelijä.
    Muotomäärittimet
    Formaatin määrittelijä Kuvaus
    % Vastaa kirjaimellista%
    c Yhdistää yhden merkin tai useita merkkejä. Jos leveys on määritetty, vastaa täsmälleen leveysmerkkejä.
    s Vastaavat peräkkäisiä muita kuin välilyöntejä. Jos leveys on määritelty, vastaa täsmälleen leveysmerkkejä tai kunnes ensimmäinen välilyönti löytyy.
    (aseta) Vastaa ei-tyhjää merkkijonoa annetusta merkistöstä. Jos on joukon alussa, kaikki merkit, joita ei ole asetettu, vastaavat toisiaan.
    d Vastaa desimaalilukua.
    i Vastaa kokonaislukua.
    o Vastaa allekirjoittamatonta oktaalilukua.
    X tai x Vastaa allekirjoittamatonta heksadesimaalilukua.
    u Vastaa allekirjoittamatonta desimaalilukua.
    A tai a, E tai e, F tai f, G tai g Vastaa liukuluvun lukua.
    n Palauttaa tähän mennessä luettujen merkkien lukumäärän.
    s Vastaa toteutuksen määrittelemää merkkijonoa, joka määrittää osoittimen.

    Joten muodon määrittelijän yleinen muoto on:
     % (*) (leveys) (pituus) määrittelijä
  • vlist: Luettelo argumenteista syötteiden vastaanottamiseksi.

vwscanf () Palautusarvo

  • Jos se onnistuu, vwscanf () -funktio palauttaa onnistuneesti luettujen argumenttien määrän.
  • EOF palautuu epäonnistumisen yhteydessä.

Esimerkki: Kuinka vwscanf () -toiminto toimii?

 #include #include #include void read( const wchar_t* format,… ) ( va_list args; va_start (args, format); vwscanf (format, args); va_end (args); ) int main () ( setlocale(LC_ALL, "en_US.UTF-8"); wchar_t name(50); wprintf(L"What is your name? "); read(L" %ls", name); wprintf(L"Hello %ls", name); return 0; )

Kun suoritat ohjelmaa, mahdollinen tulos on:

Mikä sinun nimesi on? Götz Hei Götz

Mielenkiintoisia artikkeleita...