C ++ swscanf () - C ++ стандартна библиотека

Функцията swscanf () в C ++ чете широк символ от широк буферен низ.

Функцията swscanf () е дефинирана в заглавния файл.

swscanf () прототип

 int swscanf (const wchar_t * буфер, const wchar_t * формат, …);

Функцията swscanf () чете данните от буфера и съхранява стойностите в съответните променливи.

swscanf () Параметри

  • буфер: указател към широкия буфер на низа, от който да се четат данните.
  • формат: Указател на символен низ с край до нула, който указва как да се чете въведеното. Състои се от спецификатори на формат, започващи с%.
    Форматният низ има следните части:
    • Небели символи с изключение на%, всеки от които консумира по един идентичен знак от входния поток. Това може да доведе до неуспех на функцията, ако следващият символ в потока не се сравнява равен.
    • Пробел: Всички последователни пробели се третират като единични пробели. Освен това „ n“, „ t“ и „“ се считат за еднакви.
    • Спецификация на преобразуването: Той следва следния формат:
      • Първоначален% знак, който определя началото
      • По избор *, наречен знак за потискане на заданието. Ако този знак присъства, swscanf () не присвоява резултата на нито един аргумент за получаване.
      • Незадължително положително цяло число, което указва максималната ширина на полето. Той определя максималния брой знаци, които swscanf () е разрешено да използва, когато извършва преобразуването, посочено от текущата спецификация на преобразуване.
      • Незадължителен модификатор на дължина, указващ размера на приемащия аргумент.
      • Спецификатор на формат за преобразуване.
    Спецификатори на формата
    Форматизатор Описание
    % Съвпада с буквалния%
    ° С Съвпада с един или няколко знака. Ако ширината е дефинирана, съвпада точно с ширината.
    с Съвпада с последователни символи без интервали. Ако ширината е дефинирана, съвпада точно с символите за ширина или докато не бъде намерено първото празно пространство.
    (комплект) Съответства на непразна последователност от символи от дадения набор от символи. Ако присъства в началото на набора, тогава всички символи, които не са в набора, са съвпадащи.
    д Съответства на десетично цяло число.
    i Съвпада с цяло число.
    o Съответства на неподписано осмично цяло число.
    X или x Съответства на неподписано шестнадесетично цяло число.
    u Съответства на неподписано цяло десетично число.
    A или a, E или e, F или f, G или g Съвпада с число с плаваща запетая.
    н Връща броя на прочетените до момента знаци.
    стр Съответства на дефинирана от изпълнение последователност от символи, дефинираща указател.

    Така че общият формат на спецификатора на формата е:
     Спецификатор% (*) (width) (length)
  • …: Други допълнителни аргументи за получаване на данни. Те се появяват в последователност според спецификатора на формата.

swscanf () Върната стойност

  • Функцията swscanf () връща броя на получените аргументи, успешно присвоени.
  • Ако възникне неуспех преди да бъде присвоен първият получаващ аргумент, EOF се връща.

Пример: Как работи функцията 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; )

Когато стартирате програмата, възможният изход ще бъде:

 θ е Тета

Интересни статии...