Функцията 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; )
Когато стартирате програмата, възможният изход ще бъде:
θ е Тета