C++ cout格式化输出
希望按照一定的格式進行輸出,如按十六進制輸出整數,輸出浮點數時保留小數點后面兩位,輸出整數時按 6 個數字的寬度輸出,寬度不足時左邊補 0,等等。C++ 中的 cout 對象則使用流操作算子(你也可以叫做格式控制符)或者成員函數進行控制。
使用流操作算子
C++ 中常用的輸出流操縱算子如下表所示,它們都是在頭文件 iomanip 中定義的;要使用這些流操縱算子,必須包含該頭文件。
注意:“流操縱算子”一欄中的星號*不是算子的一部分,星號表示在沒有使用任何算子的情況下,就等效于使用了該算子。例如,在默認情況下,整數是用十進制形式輸出的,等效于使用了 dec 算子。
C++ 流操縱算子
流操作算子的使用方法
使用這些算子的方法是將算子用 << 和 cout 連用。例如:
這條語句的作用是指定以十六進制形式輸出后面兩個數,因此輸出結果是:
c, 18setiosflags() 算子
setiosflags() 算子實際上是一個庫函數,它以一些標志作為參數,這些標志可以是在 iostream 頭文件中定義的以下幾種取值,它們的含義和同名算子一樣。
setiosflags() 可以使用的標志及其說明
| ios::left | 輸出數據在本域寬范圍內向左對齊 |
| ios::right | 輸出數據在本域寬范圍內向右對齊 |
| ios::internal | 數值的符號位在域寬內左對齊,數值右對齊,中間由填充字符填充 |
| ios::dec | 設置整數的基數為 10 |
| ios::oct | 設置整數的基數為 8 |
| ios::hex | 設置整數的基數為 16 |
| ios::showbase | 強制輸出整數的基數(八進制數以 0 開頭,十六進制數以 0x 打頭) |
| ios::showpoint | 強制輸出浮點數的小點和尾數 0 |
| ios::uppercase | 在以科學記數法格式 E 和以十六進制輸出字母時以大寫表示 |
| ios::showpos | 對正數顯示“+”號 |
| ios::scientific | 浮點數以科學記數法格式輸出 |
| ios::fixed | 浮點數以定點格式(小數形式)輸出 |
| ios::unitbuf | 每次輸出之后刷新所有的流 |
| ios::stdio | 每次輸出之后清除 stdout, stderr |
這些標志實際上都是僅有某比特位為 1,而其他比特位都為 0 的整數。
多個標志可以用|運算符連接,表示同時設置。例如:
cout << setiosflags(ios::scientific|ios::showpos) << 12.34;輸出結果是:
+1.234000e+001如果兩個相互矛盾的標志同時被設置,如先設置 setiosflags(ios::fixed),然后又設置 setiosflags(ios::scientific),那么結果可能就是兩個標志都不起作用。因此,在設置了某標志,又要設置其他與之矛盾的標志時,就應該用 resetiosflags 清除原先的標志。例如下面三條語句:
cout << setiosflags(ios::fixed) << 12.34 << endl; cout << resetiosflags(ios::fixed) << setiosflags(ios::scientific | ios::showpos) << 12.34 << endl; cout << resetiosflags(ios::showpos) << 12.34 << endl; //清除要輸出正號的標志輸出結果是:
12.340000 +1.234000e+001 1.234000e+001關于流操縱算子的使用,來看下面的程序。
#include <iostream> #include <iomanip> using namespace std; int main() {int n = 141;//1) 分別以十六進制、十進制、八進制先后輸出 ncout << "1)" << hex << n << " " << dec << n << " " << oct << n << endl;double x = 1234567.89, y = 12.34567;//2)保留5位有效數字cout << "2)" << setprecision(5) << x << " " << y << " " << endl;//3)保留小數點后面5位cout << "3)" << fixed << setprecision(5) << x << " " << y << endl;//4)科學計數法輸出,且保留小數點后面5位cout << "4)" << scientific << setprecision(5) << x << " " << y << endl;//5)非負數顯示正號,輸出寬度為12字符,寬度不足則用 * 填補cout << "5)" << showpos << fixed << setw(12) << setfill('*') << 12.1 << endl;//6)非負數不顯示正號,輸出寬度為12字符,寬度不足則右邊用填充字符填充cout << "6)" << noshowpos << setw(12) << left << 12.1 << endl;//7)輸出寬度為 12 字符,寬度不足則左邊用填充字符填充cout << "7)" << setw(12) << right << 12.1 << endl;//8)寬度不足時,負號和數值分列左右,中間用填充字符填充cout << "8)" << setw(12) << internal << -12.1 << endl;cout << "9)" << 12.1 << endl;return 0; }程序的輸出結果是:
1)8d 141 215 2)1.2346e+06 12.346 3)1234567.89000 12.34567 4)1.23457e+06 1.23457e+01 5)***+12.10000 6)12.10000**** 7)****12.10000 8)-***12.10000 9)12.10000需要注意的是,setw() 算子所起的作用是一次性的,即只影響下一次輸出。每次需要指定輸出寬度時都要使用 setw()。因此可以看到,第 9) 行的輸出因為沒有使用 setw(),輸出的寬度就不再是前面指定的 12 個字符。
在讀入字符串時,setw() 還能影響 cin 的行為。例如下面的程序:
#include <iostream> #include <iomanip> using namespace std; int main() {string s1, s2;cin >> setw(4) >> s1 >> setw(3) >> s2;cout << s1 << "," << s2 << endl;return 0; }輸入:
1234567890程序的輸出結果是:
1234,567說明setw(4)使得讀入 s1 時,只讀入 4 個字符,其后的setw(3)使得讀入 s2 時只讀入 3 個字符。
setw() 用于 cin 時,同樣只影響下一次的輸入。
setw() 究竟是如何實現的,以至于能和 cout 連用來指定輸出寬度?自行查看編譯器所帶的 iomanip 頭文件,然后寫一個功能和 setw() 完全相同的 mysetw()。
調用cout的成員函數
ostream 類有一些成員函數,通過 cout 調用它們也能用于控制輸出的格式,其作用和流操縱算子相同,如下表所示。
ostream 類的成員函數
setf 和 unsetf 函數用到的flag,與 setiosflags 和 resetiosflags 用到的完全相同。
這些成員函數的用法十分簡單。例如下面的三行程序:
cout.setf(ios::scientific); cout.precision(8); cout << 12.23 << endl;輸出結果是:
1.22300000e+001總結
以上是生活随笔為你收集整理的C++ cout格式化输出的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java 遍历系统根目录
- 下一篇: C++ 画直线