Функцията vsscanf () в C ++ се използва за четене на данните от буфер на низове.
Функцията vsscanf () е дефинирана в заглавния файл.
прототип на vsscanf ()
int vsscanf (const char * буфер, const char * формат, va_list vlist);
Функцията vsscanf () чете данните от буферния буфер на символен низ и съхранява стойностите в съответните местоположения, както е дефинирано от vlist.
vsscanf () Параметри
- формат: Указател на символен низ с край до нула, който указва как да се чете въведеното. Състои се от спецификатори на формат, започващи с%.
Форматният низ има следните части:- Небели символи с изключение на%, всеки от които консумира по един идентичен знак от входния поток. Това може да доведе до неуспех на функцията, ако следващият символ в потока не се сравнява равен.
- Пробел: Всички последователни пробели се третират като единични пробели. Освен това „ n“, „ t“ и „“ се считат за еднакви.
- Спецификация на преобразуването: Той следва следния формат:
- Първоначален% знак, който определя началото
- По избор *, наречен знак за потискане на заданието. Ако този знак присъства, vsscanf () не присвоява резултата на нито един аргумент за получаване.
- Незадължително положително цяло число, което указва максималната ширина на полето. Той определя максималния брой символи, които vsscanf () е разрешено да използва, когато извършва преобразуването, посочено от текущата спецификация на преобразуване.
- Незадължителен модификатор на дължина, указващ размера на приемащия аргумент.
- Спецификатор на формат за преобразуване.
Форматизатор Описание % Съвпада с буквалния% ° С Съвпада с един или няколко знака. Ако ширината е дефинирана, съвпада точно с ширината. с Съвпада с последователни символи без интервали. Ако ширината е дефинирана, съвпада точно с символите за ширина или докато не бъде намерено първото празно пространство. (комплект) Съответства на непразна последователност от символи от дадения набор от символи. Ако присъства в началото на набора, тогава всички символи, които не са в набора, са съвпадащи. д Съответства на десетично цяло число. i Съвпада с цяло число. o Съответства на неподписано осмично цяло число. X или x Съответства на неподписано шестнадесетично цяло число. u Съответства на неподписано цяло десетично число. A или a, E или e, F или f, G или g Съвпада с число с плаваща запетая. н Връща броя на прочетените до момента знаци. стр Съответства на дефинирана от изпълнение последователност от символи, дефинираща указател.
Така че общият формат на спецификатора на формата е:Спецификатор% (*) (width) (length)
- vlist: Списък с аргументи за получаване на входовете.
vsscanf () Върната стойност
- При успех функцията vsscanf () връща броя на аргументите, които са били успешно прочетени.
- При неуспех EOF се връща.
Пример: Как работи функцията vsscanf ()?
#include #include void read(const char* buf, const char * format,… ) ( va_list args; va_start (args, format); vsscanf (buf, format, args); va_end (args); ) int main () ( char buffer(100) = "Bruce Wayne Batman"; char fname(20), lname(20), superhero(20); read(buffer, "%s %s %s", fname, lname, superhero); printf("%s %s is %s.", fname, lname, superhero); return 0; )
Когато стартирате програмата, възможният изход ще бъде:
Брус Уейн е Батман.