C ++ funkcija „vsscanf ()“ naudojama duomenims nuskaityti iš eilutės buferio.
Funkcija vsscanf () yra apibrėžta antraštės faile.
„vsscanf“ () prototipas
int vsscanf (const char * buferis, const char * formatas, va_list vlist);
Funkcija „vsscanf“ () nuskaito duomenis iš simbolių eilutės buferio buferio ir išsaugo reikšmes atitinkamose vietose, kaip apibrėžta „vlist“.
vsscanf () parametrai
- formatas: žymeklis į nulinę simbolių eilutę, nurodančią, kaip skaityti įvestį. Jį sudaro formato specifikatoriai, prasidedantys%.
Formato eilutę sudaro šios dalys:- Ne tarpų simboliai, išskyrus%, kurių kiekvienas sunaudoja vieną identišką simbolį iš įvesties srauto. Tai gali sukelti funkcijos gedimą, jei kitas srauto simbolis nėra lygus.
- Baltosios erdvės simbolis: visi vienas po kito einantys simboliai yra laikomi atskirais tarpais. Toliau ' n', ' t' ir '' laikomos vienodomis.
- Konversijos specifikacija: ji pateikiama tokiu formatu:
- Pradinis% simbolis, nurodantis pradžią
- Pasirenkamas * vadinamas priskyrimą slopinančiu simboliu. Jei yra šis simbolis, vsscanf () nepriskiria rezultato jokiam gaunančiam argumentui.
- Pasirenkamas teigiamas sveikasis skaičius, nurodantis maksimalų lauko plotį. Jis nurodo maksimalų simbolių skaičių, kurį „vsscanf“ () leidžiama sunaudoti atliekant konversiją, nurodytą dabartinėje konversijos specifikacijoje.
- Pasirenkamas ilgio modifikatorius, nurodantis gaunamo argumento dydį.
- Konversijos formato specifikatorius.
Formato specifikatorius apibūdinimas % Atitinka pažodinį% c Atitinka vieną ar kelis simbolius. Jei apibrėžtas plotis, tiksliai atitinka pločio simbolius. s Atitinka vienas po kito einančius simbolius be tarpų. Jei plotis yra apibrėžtas, tiksliai atitinka pločio simbolius arba tol, kol bus rastas pirmasis tarpas. (rinkinys) Atitinka ne tuščią simbolių seką iš pateikto simbolių rinkinio. Jei aibės pradžioje yra ^, tada visi nenurodyti simboliai sutampa. d Atitinka dešimtainį skaičių. i Atitinka sveiką skaičių. o Atitinka nepasirašytą aštuonetą. X arba x Atitinka nepasirašytą šešioliktainį sveikąjį skaičių. u Atitinka nepasirašytą dešimtainį skaičių. A arba a, E arba e, F arba f, G arba g Atitinka slankiojo kablelio skaičių. n Grąžina iki šiol perskaitytų simbolių skaičių. p Atitinka įgyvendinimo apibrėžtą simbolių seką, apibrėžiančią žymeklį.
Taigi bendras formato specifikatoriaus formatas yra:% (*) (plotis) (ilgis) specifikatorius
- vlist: Įvesties gavimo argumentų sąrašas.
vsscanf () Grąžinimo vertė
- Jei pavyks, funkcija vsscanf () grąžins sėkmingai perskaitytų argumentų skaičių.
- Sugedus, EOF grąžinamas.
Pavyzdys: Kaip veikia vsscanf () funkcija?
#include #include void read(const char* buf, const char * format,… ) ( va_list args; va_start (args, format); vsscanf (buf, format, args); va_end (args); ) int main () ( char buffer(100) = "Bruce Wayne Batman"; char fname(20), lname(20), superhero(20); read(buffer, "%s %s %s", fname, lname, superhero); printf("%s %s is %s.", fname, lname, superhero); return 0; )
Kai paleisite programą, galimas rezultatas bus:
Bruce'as Wayne'as yra Betmenas.