Funktionen swscanf () i C ++ läser bred karaktär från bredsträngsbuffert.
Funktionen swscanf () definieras i rubrikfilen.
swscanf () prototyp
int swscanf (const wchar_t * buffert, const wchar_t * format, …);
Funktionen swscanf () läser data från bufferten och lagrar värdena i respektive variabler.
swscanf () Parametrar
- buffert: pekare till den breda strängbufferten för att läsa data från.
- format: pekare till en nollavslutad 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 finns, tilldelar swscanf () inte resultatet till något mottagande argument.
- Ett valfritt positivt heltal som anger maximal fältbredd. Den anger det maximala antalet tecken som swscanf () får konsumera när den konvertering som anges i den aktuella konverteringsspecifikationen.
- 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
- …: Andra ytterligare argument för att ta emot data. De förekommer i en sekvens enligt formatspecifikatorn.
swscanf () Returvärde
- Funktionen swscanf () returnerar antalet mottagningsargument som tilldelats.
- Om fel inträffar innan det första mottagande argumentet tilldelades returneras EOF .
Exempel: Hur fungerar swscanf ()?
#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; )
När du kör programmet blir en möjlig utdata:
θ är Theta