C ++ swscanf () - biblioteka standardowa C ++

Funkcja swscanf () w C ++ odczytuje szeroki znak z bufora szerokich ciągów.

Funkcja swscanf () jest zdefiniowana w pliku nagłówkowym.

prototyp swscanf ()

 int swscanf (const wchar_t * bufor, format const wchar_t *,…);

Funkcja swscanf () odczytuje dane z bufora i zapisuje wartości w odpowiednich zmiennych.

swscanf () Parametry

  • bufor: wskaźnik do szerokiego buforu ciągów, z którego mają być odczytywane dane.
  • format: wskaźnik do ciągu znaków zakończonych znakiem null, który określa sposób odczytywania danych wejściowych. Składa się ze specyfikatorów formatu zaczynających się od%.
    Ciąg formatu składa się z następujących części:
    • Znaki inne niż białe znaki, z wyjątkiem%, z których każdy zużywa jeden identyczny znak ze strumienia wejściowego. Może to spowodować niepowodzenie funkcji, jeśli następny znak w strumieniu nie jest równy.
    • Białe znaki: wszystkie następujące po sobie białe znaki są traktowane jako pojedyncze białe znaki. Ponadto „ n”, „ t” i „” są uważane za takie same.
    • Specyfikacja konwersji: ma następujący format:
      • Początkowy znak%, który określa początek
      • Opcjonalny *, nazywany znakiem tłumiącym przypisanie. Jeśli ten znak jest obecny, swscanf () nie przypisuje wyniku do żadnego odbieranego argumentu.
      • Opcjonalna dodatnia liczba całkowita, która określa maksymalną szerokość pola. Określa maksymalną liczbę znaków, jaką swscanf () może wykorzystać podczas wykonywania konwersji określonej w bieżącej specyfikacji konwersji.
      • Opcjonalny modyfikator długości określający rozmiar otrzymywanego argumentu.
      • Specyfikator formatu konwersji.
    Specyfikatory formatu
    Specyfikator formatu Opis
    % Dopasowuje dosłowne%
    do Dopasowuje pojedynczy znak lub wiele znaków. Jeśli zdefiniowano szerokość, dopasowuje dokładnie znaki szerokości.
    s Dopasowuje kolejne znaki niebędące białymi znakami. Jeśli zdefiniowano szerokość, dopasowuje dokładnie znaki szerokości lub do znalezienia pierwszej spacji.
    (zestaw) Dopasowuje niepusty ciąg znaków z podanego zestawu znaków. Jeśli występuje na początku zbioru, to dopasowywane są wszystkie znaki spoza zbioru.
    re Dopasowuje dziesiętną liczbę całkowitą.
    ja Dopasowuje liczbę całkowitą.
    o Dopasowuje ósemkową liczbę całkowitą bez znaku.
    X lub x Dopasowuje szesnastkową liczbę całkowitą bez znaku.
    u Dopasowuje dziesiętną liczbę całkowitą bez znaku.
    A lub a, E lub e, F lub f, G lub g Dopasowuje liczbę zmiennoprzecinkową.
    n Zwraca liczbę odczytanych dotychczas znaków.
    p Dopasowuje sekwencję znaków zdefiniowaną przez implementację definiującą wskaźnik.

    Zatem ogólny format specyfikatora formatu to:
     Specyfikator% (*) (szerokość) (długość)
  • …: Inne dodatkowe argumenty za otrzymywaniem danych. Występują w sekwencji zgodnie ze specyfikatorem formatu.

swscanf () Zwracana wartość

  • Funkcja swscanf () zwraca liczbę pomyślnie przypisanych otrzymanych argumentów.
  • Jeśli błąd wystąpi przed przypisaniem pierwszego argumentu odbioru, zwracany jest EOF .

Przykład: Jak działa funkcja 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; )

Po uruchomieniu programu możliwe wyjście to:

 θ to Theta

Interesujące artykuły...