Функція vsnprintf () в C ++ використовується для запису відформатованого рядка в буфер рядків.
На відміну від vsprintf (), максимальна кількість символів, які можна записати в буфер, вказано в vsnprintf()
.
прототип vsnprintf ()
int vsnprintf (буфер char *, size_t buf_size, формат const char *, va_list vlist);
vsnprintf()
Функція записує рядок , на яку вказує формат для рядка символів буфера. Максимальна кількість символів, яку можна записати, - buf_size. Після запису символів додається закінчувальний нульовий символ. Якщо buf_size дорівнює нулю, нічого не записується, а буфер може бути нульовим покажчиком.
Формат рядка може містити специфікатори формату, що починаються з%, які замінюються значеннями змінних, які передаються як список vlist.
Це визначається у файлі заголовка.
Параметри vsnprintf ()
- буфер: вказівник на рядок символів для запису результату.
- buf_size: Максимальна кількість символів для запису.
- формат: вказівник на рядок із нульовим завершенням, який записується у файловий потік. Він складається з символів разом із необов’язковими специфікаторами формату, що починаються з%.
Специфікатори формату замінюються значеннями відповідних змінних, що слідують за рядком формату.
Специфікатор формату складається з таких частин:
- Провідний знак%
- Прапори: необов’язковий один або кілька прапорів, що змінює поведінку перетворення.
- -: Ліворуч обґрунтуйте результат у полі. За замовчуванням це правильно виправдано.
- +: Знак результату додається до початку значення, навіть для позитивних результатів.
- Пробіл: Якщо знаку немає, пробіл приєднується до початку результату.
- #: Виконується альтернативна форма перетворення.
- 0: використовується для цілого числа та числа з плаваючою комою. Провідні нулі використовуються для заповнення цифр замість пробілу.
- Ширина: необов’язкове * або ціле значення, що використовується для вказівки поля мінімальної ширини.
- Точність: Необов’язкове поле, що складається з a. після чого * або ціле число, або нічого, щоб вказати точність.
- Довжина: необов’язковий модифікатор довжини, який визначає розмір аргументу.
- Специфікатор: специфікатор формату перетворення. Доступні специфікатори формату такі:
Специфікатор формату Опис % Відбитків% c Пише одного персонажа s Записує рядок символів d або i Перетворює підписане ціле число в десяткове подання o Перетворює ціле число без знака у вісімкове представлення X або x Перетворює ціле число без знака в шістнадцяткове подання u Перетворює ціле число без знака в десяткове подання F або f Перетворює число з плаваючою точкою в десяткове подання Е або е Перетворює число з плаваючою комою в десятковий запис степеня A або a Перетворює число з плаваючою комою в шістнадцятковий показник G або g Перетворює число з плаваючою комою в десятковий або десятковий запис степеня п Повертає кількість символів, записаних дотепер цим викликом функції. Результат записується у значення, на яке вказує аргумент стор Пише послідовність символів реалізації, що визначає покажчик. Отже, загальним форматом специфікатора формату є:
%(flags)(width)(.precision)(length)specifier
- vlist: список аргументів, що містять дані для запису.
vsnprintf () Повернене значення
- У разі успіху
vsnprintf()
функція повертає кількість записаних символів. - При відмові повертає від'ємне значення.
- Коли довжина відформатованого рядка перевищує buf_size, його потрібно скоротити. У таких випадках
vsnprintf()
функція повертає загальну кількість символів, за винятком закінчувального нульового символу, який був би записаний, якби не було встановлено обмеження buf_size.
Приклад: Як працює функція vsnprintf ()
#include #include void write(char* buf, int buf_size, const char *fmt,… ) ( va_list args; va_start(args, fmt); vsnprintf(buf, buf_size, fmt, args); va_end(args); ) int main () ( char buffer(100); char fname(20) = "Bjarne"; char lname(20) = "Stroustrup"; char lang(5) = "C++"; write(buffer, 27, "%s was created by %s %s", lang, fname, lname); printf("%s", buffer); return 0; )
Коли ви запускаєте програму, результат буде:
C ++ був створений Bjarne