Funkcija vfwscanf () C ++ tiek izmantota, lai nolasītu platas rakstzīmju virknes no plaša virknes bufera.
Funkcija vfwscanf () ir definēta galvenes failā.
vswscanf () prototips
int vswscanf (const wchar_t * buferis, const wchar_t * formāts, va_list vlist);
Funkcija vfwscanf () nolasa datus no plašā virknes bufera bufera un saglabā vērtības attiecīgajās vietās, kā noteikts vlist.
vswscanf () parametri
- buferis: rādītājs uz nulles izbeigtu plašu virkni, no kuras nolasīt datus.
- formāts: rādītājs ar nulli izbeigtu plašu rakstzīmju virkni, kas norāda, kā lasīt ievadi. Tas sastāv no formāta specifikatoriem, kas sākas ar%.
Formāta virknei ir šādas daļas:- Rakstzīmes, kas nav atstarpes, izņemot%, no kurām katra patērē vienu identisku rakstzīmi no ievades straumes. Tas var izraisīt funkcijas kļūmi, ja straumes nākamais raksturs nav vienāds.
- Atstarpes rakstzīme: visas secīgās atstarpes rakstzīmes tiek uzskatītas par vienu atstarpes rakstzīmi. Tālāk ' n', ' t' un '' tiek uzskatīti par vienādiem.
- Reklāmguvumu specifikācija: tā tiek izmantota šādā formātā:
- Sākotnējais raksturs%, kas norāda sākumu
- Neobligāts *, ko sauc par uzdevumu nomācošu rakstzīmi. Ja ir šī rakstzīme, vfwscanf () nepiešķir rezultātu nevienam saņemšanas argumentam.
- Neobligāts pozitīvs vesels skaitlis, kas norāda lauka maksimālo platumu. Tas norāda maksimālo rakstzīmju skaitu, ko vfwscanf () atļauts patērēt, veicot pašreizējā reklāmguvumu specifikācijā norādīto pārveidošanu.
- Neobligāts garuma pārveidotājs, kas norāda saņemošā argumenta lielumu.
- Reklāmguvuma formāta norādītājs.
Formāta specifikators Apraksts % Atbilst burtiskajam% c Sakrīt ar vienu vai vairākām rakstzīmēm. Ja platums ir definēts, precīzi atbilst platuma rakstzīmēm. s Saskaņo secīgas rakstzīmes, kas nav atstarpes. Ja platums ir noteikts, precīzi atbilst platuma rakstzīmēm vai līdz tiek atrasts pirmais atstarpe. (komplekts) Sakrīt ar tukšo rakstzīmju secību no norādītās rakstzīmju kopas. Ja kopas sākumā ir ^, tad visas rakstzīmes, kas nav iestatītas, tiek saskaņotas. d Atbilst decimāldaļskaitlim. i Sakrīt ar veselu skaitli. o Sakrīt ar neparakstītu astotnieku. X vai x Atbilst neparakstītam heksadecimālam skaitlim. u Sakrīt ar neparakstītu decimāldaļskaitli. A vai a, E vai e, F vai f, G vai g Atbilst peldošā komata skaitlim. n Atgriež līdz šim nolasīto rakstzīmju skaitu. lpp Atbilst ieviešanas definētai rakstzīmju secībai, kas nosaka rādītāju.
Tātad formāta specifikatora vispārējais formāts ir:% (*) (platums) (garums) specifikators
- vlist: argumentu saraksts ievades saņemšanai.
vswscanf () Atgriežamā vērtība
- Ja tas izdodas, funkcija vfwscanf () atgriež veiksmīgi nolasīto argumentu skaitu.
- Pēc neveiksmes EOF tiek atgriezts.
Piemērs: Kā darbojas funkcija vswscanf ()?
#include #include #include void read( const wchar_t* buffer, const wchar_t* format,… ) ( va_list args; va_start (args, format); vswscanf (buffer, format, args); va_end (args); ) int main() ( setlocale(LC_ALL, "en_US.UTF-8"); wchar_t symbol() = L"u0fd7u00c6u20b9u2127u17d8"; wchar_t str(20); read(symbol, L"%ls", str); wprintf(L"Random Symbols"); for (int i=0; i
When you run the program, a possible output will be:
Random Symbols ࿗ Æ ₹ ℧ ៘