Funktionen vwscanf () i C ++ används för att läsa bred teckensträng från stdin.
Funktionen vwscanf () definieras i rubrikfilen.
vwscanf () prototyp
int vwscanf (const wchar_t * format, va_list vlist);
Funktionen vwscanf () läser data från stdin och lagrar värdena på respektive platser som definieras av vlist.
vwscanf () Parametrar
- format: Pekare till en null-avslutad bred teckensträng som anger hur ingången ska läsas. Den består av formatspecifikationer som börjar med%.
Formatsträngen har följande delar:- Icke-blankstegstecken utom% som var och en förbrukar ett identiskt tecken från inmatningsströmmen. Det kan få funktionen att misslyckas om nästa tecken i strömmen inte jämför lika.
- Mellanslagstecken: Alla efterföljande blankstegstecken behandlas som enstaka mellanslagstecken. Vidare anses ' n', ' t' och '' vara samma.
- Konverteringsspecifikation: Den följer följande format:
- Initialt% -tecken som anger början
- En valfri * kallad tilldelningsundertryckande karaktär. Om denna karaktär är närvarande tilldelar vwscanf () inte resultatet till något mottagande argument.
- Ett valfritt positivt heltal som anger maximal fältbredd. Den anger det maximala antalet tecken som vwscanf () får konsumera när den konvertering som anges i den aktuella konverteringsspecifikationen görs.
- En valfri längdmodifierare som anger storleken på det mottagande argumentet.
- En konverteringsformatspecifikator.
Format Specifier Beskrivning % Matchar den bokstavliga% c Matchar en enstaka karaktär eller flera tecken. Om bredd definieras matchar den exakt breddtecken. s Matchar på varandra följande icke-blankstegstecken. Om bredd är definierad matchar den exakt breddtecken eller tills första vita utrymmet hittas. (uppsättning) Matchar en icke tom teckenföljd från den givna uppsättningen tecken. Om är närvarande i början av uppsättningen matchas alla tecken som inte finns i uppsättningen. d Matchar ett decimaltal. i Matchar ett heltal. o Matchar ett osignerat oktalt heltal. X eller x Matchar ett osignerat hexadecimalt heltal. u Matchar ett osignerat decimaltal. A eller a, E eller e, F eller f, G eller g Matchar ett flytande nummer. n Returnerar antalet lästa tecken hittills. sid Matchar en implementeringsdefinierad teckensekvens som definierar en pekare.
Så det allmänna formatet för formatspecifikatorn är:% (*) (bredd) (längd) specificerare
- vlist: En lista med argument för att ta emot ingångarna.
vwscanf () Returvärde
- Om det lyckas returnerar funktionen vwscanf () antalet lästa argument.
- Vid fel returneras EOF.
Exempel: Hur fungerar vwscanf ()?
#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; )
När du kör programmet blir en möjlig utdata:
Vad heter du? Götz Hej Götz