Toimintoa vfscanf () C ++: ssa käytetään tietojen lukemiseen tiedostovirrasta.
Vfscanf () -funktio määritetään otsikkotiedostossa.
vfscanf () -prototyyppi
int vfscanf (FILE * stream, const char * format, va_list vlist);
Vfscanf () -toiminto lukee tiedot tiedostovirrasta ja tallentaa arvot vastaaviin sijainteihin, kuten vlist määrittelee.
vfscanf () -parametrit
- stream: Syötä tiedostovirta, josta tiedot voidaan lukea.
- muoto: Osoitin nollapäätteiseen merkkijonoon, joka määrittää, miten syötettä luetaan. Se koostuu muodon määrittelijöistä, jotka alkavat%.
- vlist: Muuttuja-argumenttiluettelo, johon arvot tallennetaan
. Formaattimerkkijonossa 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ä, vfscanf () 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 vfscanf () saa kuluttaa tehdessään nykyisen muunnosmäärityksen mukaisen muunnoksen.
- Valinnainen pituusmuunnin, joka määrittää vastaanottavan argumentin koon.
- Muunnosmuodon määrittelijä.
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.
vfscanf () Palautusarvo
- Jos se onnistuu, vfscanf () -funktio palauttaa onnistuneesti luettujen argumenttien määrän.
- EOF palautuu epäonnistumisen yhteydessä.
Esimerkki: Kuinka vfscanf () -toiminto toimii?
#include #include void read(FILE* fp, const char * format,… ) ( va_list args; va_start (args, format); vfscanf (fp, format, args); va_end (args); ) int main () ( char myFriends(5)(20) = ("Robert", "Syd", "Brian", "Eddie", "Ray"); FILE *fp = fopen("example.txt","w+"); char name(20); for (int i=0; i<5; i++) fprintf(fp, "%s ", myFriends(i)); rewind(fp); printf("Here are the list of my friends"); for (int i=0; i<5; i++) ( read(fp, "%s ", &name); printf("%s", name); ) fclose(fp); return 0; )
Kun suoritat ohjelmaa, mahdollinen tulos on:
Tässä on luettelo ystävistäni Robert Syd Brian Eddie Ray