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()。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。