Funktsioon swscanf () C ++ -s loeb laia märki laiast stringipuhvrist.
Funktsioon swscanf () on määratletud päisefailis.
swscanf () prototüüp
int swscanf (const wchar_t * puhver, const wchar_t * formaat,…);
Funktsioon swscanf () loeb andmeid puhvrist ja salvestab väärtused vastavatesse muutujatesse.
swscanf () parameetrid
- puhver: laia stringi puhvri kursor andmete lugemiseks.
- formaat: nulliga lõpetatud tähemärgi kursor, mis määrab, kuidas sisendit lugeda. See koosneb vorminguspetsifikaatoritest algusega%.
Formaadistringil on järgmised osad:- Muud tühimärgid, välja arvatud%, millest igaüks kulutab sisendvoost ühte identset tähemärki. See võib põhjustada funktsiooni nurjumise, kui voo järgmine märk ei võrdu võrdsega.
- Tühimärk: kõiki järjestikuseid tühimärke käsitletakse ühe tühimärgina. Edasi loetakse tähti ' n', ' t' ja '' samaks.
- Teisenduse spetsifikatsioon: see järgib järgmist vormingut:
- Algne% märk, mis määrab alguse
- Valikuline *, mida nimetatakse määramist summutavaks tähemärgiks. Kui see märk on olemas, ei määra swscanf () tulemust ühelegi vastuvõtuargumendile.
- Valikuline positiivne täisarv, mis määrab välja maksimaalse laiuse. See määrab maksimaalse märkide arvu, mida swscanf () võib praeguse teisendusspetsifikatsiooniga määratud teisenduse tegemisel tarbida.
- Valikuline pikkuse muutja, mis määrab vastuvõtu argumendi suuruse.
- Teisendusvormingu täpsustaja.
Vorminguspetsifikaator Kirjeldus % Sobib sõna otseses mõttes% c Sobib ühe või mitme tähemärgiga. Kui laius on määratletud, sobib see täpselt laiuse tähemärkidega. s Sobib järjestikuste tühimärkidega. Kui laius on määratletud, vastab see täpselt laiuse tähemärgile või kuni leitakse esimene tühik. (komplekt) Sobib antud tähemärkide komplekti mittetühja jada. Kui hulga alguses on ^, siis sobitatakse kõik tähemärgid, mida pole komplektis. d Sobib kümnendarvuni. i Sobib täisarvuga. o Sobib allkirjastamata kaheksandarvuga. X või x Sobib allkirjastamata kuueteistkümnendsüsteemi täisarvuga. u Sobib allkirjastamata kümnendarvuga. A või a, E või e, F või f, G või g Sobib ujukomaarvuga. n Tagastab seni loetud märkide arvu. lk Vastab rakenduse määratletud märgijärjestusele, mis määrab kursori.
Seega on vorminguspetsifikaatori üldine vorming:% (*) (laius) (pikkus) täpsustaja
- …: Muud täiendavad argumendid andmete vastuvõtmiseks. Need esinevad järjestuses vastavalt vorminguspetsifikaatorile.
swscanf () Tagastusväärtus
- Funktsioon swscanf () tagastab edukalt määratud vastuvõtvate argumentide arvu.
- Kui tõrge ilmneb enne esimese vastuvõtuargumendi määramist, tagastatakse EOF .
Näide: Kuidas funktsioon swscanf () töötab?
#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; )
Programmi käivitamisel on võimalik väljund:
θ on Theta