C++ 中的wprintf() 函数用于将格式化的宽字符串写入标准输出。
wprintf() 函数在<cwchar> 头文件中定义。
wprintf()原型
int wprintf( const wchar_t* format, ... );
wprintf() 函数将 format
指向的宽字符串写入标准输出。宽字符串格式可能包含以 % 开头的格式说明符,这些说明符被作为附加参数传递给 wprintf() 函数的变量值替换。
参数:
format
:指向写入标准输出的空终止宽字符串的指针。它由宽字符以及以 % 开头的可选格式说明符组成。格式说明符由遵循格式的各个变量的值替换。
格式说明符包含以下部分:- 前导 % 符号
- 标志:可选的一个或多个标志,用于修改转换行为。
- -:左对齐字段内的结果。默认情况下它是右对齐的。
- +:结果的符号附加到值的开头,即使是正面结果也是如此。
- 空格:如果没有符号,则在结果的开头附加一个空格。
- #:执行另一种形式的转换。
- 0:用于整数和浮点数。前导零用于填充数字而不是空格。
- 宽度:可选的 * 或整数值,用于指定最小宽度字段。
- 精度:一个可选字段,由 .后跟 * 或整数或不指定精度。
- 长度:一个可选的长度修饰符,指定参数的大小。
- 说明符:转换格式说明符。可用的格式说明符如下:
格式说明符 格式说明符 说明 % 印刷 % c 写入单个字符 s 写入一个字符串 d 或 i 将有符号整数转换为十进制表示 o 将无符号整数转换为八进制表示 X 或 x 将无符号整数转换为十六进制表示 u 将无符号整数转换为十进制表示 F 或 f 将浮点数转换为十进制表示 E 或 e 将浮点数转换为十进制 index 表示法 一个或一个 将浮点数转换为十六进制 index 克或克 将浮点数转换为十进制或十进制 index 表示法 n 返回到目前为止此函数调用写入的字符数。结果写入参数指向的值 p 编写定义指针的实现定义的字符序列。
所以格式说明符的一般格式是:%[flags][width][.precision][length]specifier
- …:指定要打印的数据的其他附加参数。它们根据格式说明符按顺序出现。
返回:
- 如果成功,wprintf() 函数会返回写入的字符数。
- 失败时返回负值。
示例:wprintf() 函数如何工作?
#include <cwchar>
#include <clocale>
int main()
{
wint_t x = 5;
wchar_t name[] = L"André ";
setlocale(LC_ALL, "en_US.UTF-8");
wprintf(L"x = %d \n", x);
wprintf(L"Hello %ls \n", name);
return 0;
}
运行程序时,输出将是:
x = 5 Hello André
相关用法
- C++ wcstold()用法及代码示例
- C++ wscanf()用法及代码示例
- C++ wctrans()用法及代码示例
- C++ wmemcmp()用法及代码示例
- C++ wcerr用法及代码示例
- C++ wcsftime()用法及代码示例
- C++ wcstod()用法及代码示例
- C++ wcscspn()用法及代码示例
- C++ wcsncmp()用法及代码示例
- C++ wcin用法及代码示例
- C++ wcstok()用法及代码示例
- C++ wmemchr()用法及代码示例
- C++ wcsstr()用法及代码示例
- C++ wcsrchr()用法及代码示例
- C++ wmemcpy()用法及代码示例
- C++ wctob()用法及代码示例
- C++ wcsncpy()用法及代码示例
- C++ wcslen()用法及代码示例
- C++ wcsspn()用法及代码示例
- C++ wclog用法及代码示例
注:本文由纯净天空筛选整理自 C++ wprintf()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。