Функція vfwprintf () у C ++ використовується для запису відформатованого широкого рядка до потоку файлів.
Функція vfwprintf () визначена у файлі заголовка.
прототип vfwprintf ()
int vfwprintf (ФАЙЛ * потік, формат const wchar_t *, список va_list vlist);
Функція vfwprintf () записує широкий рядок, на який вказує формат, у потік файлового потоку. Формат широкого рядка може містити специфікатори формату, що починаються з%, які замінюються значеннями змінних, які передаються як список vlist.
vfwprintf () Параметри
- потік: вихідний потік файлу для запису результату
- формат: вказівник на нульовий завершений широкий рядок, який записується в потік. Він складається з символів разом із необов’язковими специфікаторами формату, що починаються з%. Специфікатори формату замінюються значеннями відповідних змінних, що слідують за форматом.
Специфікатор формату складається з таких частин:- Провідний знак%
- Прапори: необов’язковий один або кілька прапорів, що змінює поведінку перетворення.
- -: Ліворуч обґрунтуйте результат у полі. За замовчуванням це правильно виправдано.
- +: Знак результату додається до початку значення, навіть для позитивних результатів.
- Пробіл: Якщо знаку немає, пробіл приєднується до початку результату.
- #: Виконується альтернативна форма перетворення.
- 0: використовується для цілого числа та числа з плаваючою комою. Провідні нулі використовуються для заповнення цифр замість пробілу.
- Ширина: необов’язкове * або ціле значення, що використовується для вказівки поля мінімальної ширини.
- Точність: Необов’язкове поле, що складається з a. після чого * або ціле число, або нічого, щоб вказати точність.
- Довжина: необов’язковий модифікатор довжини, який визначає розмір аргументу.
- Специфікатор: специфікатор формату перетворення. Доступні специфікатори формату такі:
Специфікатор формату Опис % Відбитків% c Пише одного персонажа s Записує рядок символів d або i Перетворює підписане ціле число в десяткове подання o Перетворює ціле число без знака у вісімкове представлення X або x Перетворює ціле число без знака в шістнадцяткове подання u Перетворює ціле число без знака в десяткове подання F або f Перетворює число з плаваючою точкою в десяткове подання Е або е Перетворює число з плаваючою комою в десятковий запис степеня A або a Перетворює число з плаваючою комою в шістнадцятковий показник G або g Перетворює число з плаваючою комою в десятковий або десятковий запис степеня п Повертає кількість символів, записаних дотепер цим викликом функції. Результат записується у значення, на яке вказує аргумент стор Пише послідовність символів реалізації, що визначає покажчик.
Отже, загальним форматом специфікатора формату є:Специфікатор% (прапори) (ширина) (. точність) (довжина)
- vlist: список аргументів, що містять дані для запису.
vfwprintf () Повертається значення
- У разі успіху функція vfwprintf () повертає кількість написаних широких символів.
- При відмові повертає від'ємне значення.
Приклад: Як працює функція vfwprintf ()?
#include #include #include void write(const wchar_t *fmt,… ) ( va_list args; va_start(args, fmt); vfwprintf(fmt, args); va_end(args); ) int main () ( wchar_t desc(5)(10) = (L"Eta",L"Theta",L"Iota",L"Kappa",L"Lamda"); int x = 0; setlocale(LC_ALL, "en_US.UTF-8"); wprintf(L"Some Greek Letters"); for (wchar_t i=L'u03b7'; i<=L'u03bb'; i++) ( write(L"%ls : %lc", desc(x), i); x++; ) return 0; )
Коли ви запускаєте програму, у example.txt буде записано таке:
Деякі грецькі літери Eta: η Theta: θ Iota: ι Kappa: κ Lamda: λ