Функция vfwprintf () в C ++ используется для записи отформатированной широкой строки в файловый поток.
Функция vfwprintf () определена в заголовочном файле.
vfwprintf () прототип
int vfwprintf (FILE * поток, const wchar_t * format, va_list vlist);
Функция vfwprintf () записывает широкую строку, на которую указывает format, в поток файлового потока. Формат широкой строки может содержать спецификаторы формата, начинающиеся с%, которые заменяются значениями переменных, которые передаются в виде списка vlist.
Параметры vfwprintf ()
- stream: поток выходного файла для записи результата.
- формат: указатель на широкую строку с завершающим нулем, которая записывается в поток. Он состоит из символов и дополнительных спецификаторов формата, начинающихся с%. Спецификаторы формата заменяются значениями соответствующих переменных, следующих за форматом.
Спецификатор формата состоит из следующих частей:- Ведущий знак%
- Флаги: необязательный один или несколько флагов, которые изменяют поведение преобразования.
- -: Выровнять результат по левому краю внутри поля. По умолчанию выравнивается по правому краю.
- +: Знак результата прикрепляется к началу значения даже для положительных результатов.
- Пробел: при отсутствии знака ставится пробел в начале результата.
- #: Выполняется альтернативная форма преобразования.
- 0: используется для целых чисел и чисел с плавающей запятой. Для дополнения чисел вместо пробела используются ведущие нули.
- Ширина: необязательное * или целочисленное значение, используемое для указания поля минимальной ширины.
- Точность: необязательное поле, состоящее из. за которым следует *, целое число или ничего, чтобы указать точность.
- Длина: необязательный модификатор длины, указывающий размер аргумента.
- Спецификатор: спецификатор формата преобразования. Доступные спецификаторы формата следующие:
Описатель формата Описание % Печать% c Записывает одиночный символ s Записывает символьную строку д или я Преобразует целое число со знаком в десятичное представление о Преобразует целое число без знака в восьмеричное представление X или x Преобразует целое число без знака в шестнадцатеричное представление. ты Преобразует целое число без знака в десятичное представление F или F Преобразует число с плавающей запятой в десятичное представление E или e Преобразует число с плавающей запятой в представление десятичной степени А или а Преобразует число с плавающей запятой в шестнадцатеричную экспоненту 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: λ