C++ cout格式化輸出(輸出格式)完全攻略


 

使用流操作算子

它們都是在頭文件 iomanip 中定義的;要使用這些流操縱算子,必須包含該頭文件。

 

表1:C++ 流操縱算子
流操縱算子 作  用
*dec 以十進制形式輸出整數
hex 以十六進制形式輸出整數
oct 以八進制形式輸出整數
fixed 以普通小數形式輸出浮點數
scientific 以科學計數法形式輸出浮點數
left 左對齊,即在寬度不足時將填充字符添加到右邊
*right 右對齊,即在寬度不足時將填充字符添加到左邊
setbase(b) 設置輸出整數時的進制,b=8、10 或 16
setw(w) 指定輸出寬度為 w 個字符,或輸人字符串時讀入 w 個字符
setfill(c) 在指定輸出寬度的情況下,輸出的寬度不足時用字符 c 填充(默認情況是用空格填充)
setprecision(n)

設置輸出浮點數的精度為 n。在使用非 fixed 且非 scientific 方式輸出的情況下,n 即為有效數字最多的位數,如果有效數字位數超過 n,

則小數部分四舍五人,或自動變為科學計 數法輸出並保留一共 n 位有效數字。在使用 fixed 方式和 scientific 方式輸出的情況下,n 是小數點后面應保留的位數。

setiosflags(flag) 將某個輸出格式標志置為 1
resetiosflags(flag) 將某個輸出格式標志置為 0
boolapha 把 true 和 false 輸出為字符串
*noboolalpha 把 true 和 false 輸出為 0、1
showbase 輸出表示數值的進制的前綴
*noshowbase 不輸出表示數值的進制.的前綴
showpoint 總是輸出小數點
*noshowpoint 只有當小數部分存在時才顯示小數點
showpos 在非負數值中顯示 +
*noshowpos 在非負數值中不顯示 +
*skipws 輸入時跳過空白字符
noskipws 輸入時不跳過空白字符
uppercase 十六進制數中使用 A~E。若輸出前綴,則前綴輸出 0X,科學計數法中輸出 E
*nouppercase 十六進制數中使用 a~e。若輸出前綴,則前綴輸出 0x,科學計數法中輸出 e。
internal 數值的符號(正負號)在指定寬度內左對齊,數值右對 齊,中間由填充字符填充。

 

 

流操作算子的使用方法

  使用這些算子的方法是將算子用 << 和 cout 連用。例如:

  cout << hex << 12 << "," << 24;

 

setiosflags() 算子
  setiosflags() 算子實際上是一個庫函數,它以一些標志作為參數,這些標志可以是在 iostream 頭文件中定義的以下幾種取值,它們的含義和同名算子一樣。
表2:setiosflags() 可以使用的標志及其說明

表2: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

 

 

#include <iostream> #include <iomanip>
using namespace std; int main() { int n = 141; //1) 分別以十六進制、十進制、八進制先后輸出 n 
    cout << "1)" << hex << n << " " << dec << n << " " << oct << n << endl; / / 1)8d 141 215 double x = 1234567.89, y = 12.34567; //2)保留5位有效數字
    cout << "2)" << setprecision(5) << x << " " << y << " " << endl; //2)1.2346e+06 12.346 //3)保留小數點后面5位
    cout << "3)" << fixed << setprecision(5) << x << " " << y << endl;    //3)1234567.89000 12.34567 //4)科學計數法輸出,且保留小數點后面5位
    cout << "4)" << scientific << setprecision(5) << x << " " << y << endl; //4)1.23457e+06 1.23457e+01 //5)非負數顯示正號,輸出寬度為12字符,寬度不足則用 * 填補
    cout << "5)" << showpos << fixed << setw(12) << setfill('*') << 12.1 << endl; //5)***+12.10000 //6)非負數不顯示正號,輸出寬度為12字符,寬度不足則右邊用填充字符填充
    cout << "6)" << noshowpos << setw(12) << left << 12.1 << endl;      //6)12.10000**** //7)輸出寬度為 12 字符,寬度不足則左邊用填充字符填充
    cout << "7)" << setw(12) << right << 12.1 << endl;                //7)****12.10000 //8)寬度不足時,負號和數值分列左右,中間用填充字符填充
    cout << "8)" << setw(12) << internal << -12.1 << endl;           //8)-***12.10000 cout << "9)" << 12.1 << endl; //9)12.10000 return 0; }

  注意:setw() 算子所起的作用是一次性的,即只影響下一次輸出。每次需要指定輸出寬度時都要使用 setw()。

  在讀入字符串時,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

  

 

調用cout的成員函數

ostream 類有一些成員函數,通過 cout 調用它們也能用於控制輸出的格式,其作用和流操縱算子相同

表3:ostream 類的成員函數
成員函數 作用相同的流操縱算子 說明
precision(n) setprecision(n) 設置輸出浮點數的精度為 n。
width(w) setw(w) 指定輸出寬度為 w 個字符。
fill(c) setfill (c) 在指定輸出寬度的情況下,輸出的寬度不足時用字符 c 填充(默認情況是用空格填充)。
setf(flag) setiosflags(flag) 將某個輸出格式標志置為 1。
unsetf(flag) resetiosflags(flag) 將某個輸出格式標志置為 0。

 

cout.setf(ios::scientific); cout.precision(8); cout << 12.23 << endl; 輸出結果是: 1.22300000e+001

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM