程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> C++的輸出格式控制技巧分析

C++的輸出格式控制技巧分析

編輯:C++入門知識

C++中,將數據從一個對象到另一個對象的流動抽象為“流”stream)。按流動的方向不同,構成輸入/輸出流。對於流數據的輸入輸出格式,C++提供了兩種不同的控制方式,一種是使用ios_base類提供的setf、width等函數設置輸入輸出格式,另一種是通過重載的格式控制符“<<”、“>>”以及流格式控制對象進行設置。

大部分流的輸入輸出格式可以用setf函數來設置。該函數有兩種重載形式。其但參數的setf原型為:

fmtflage setf(fmtfalg flag)

參數flag說明所要設置的格式,由ios_base給出,可取如下枚舉常量:

  1. enum{  
  2. left =0x0001, //在域中靠左輸出  
  3. right =0x0002, //在域中靠右輸出  
  4. internal =0x0004, //符號靠左數值靠右輸出,中間默認以空格填充  
  5. dec =0x0008, //數值以十進制輸出  
  6. hex =0x0010, //以16進制輸出  
  7. oct =0x0020, //8進制輸出  
  8. fixed =0x0040, //浮點數以小數方式輸出  
  9. scientific =0x0080, //浮點數以科學計數方式輸出  
  10. boolalpha =0x0100, //布爾值以true/false方式輸出  
  11. showbase =0x0200, //8進制前面加0做指示符,16進制前面加0x做指示符  
  12. showpoint =0x0400, //不管小數點和尾部的0是否可省略不寫,都輸出小數點和0  
  13. showpos =0x0800, //在正數前面輸出+號  
  14. skipws =0x1000, //不讀入空白字符(空格,制表符\t,回車\r,和換行\n)  
  15. unitbuf =0x2000, //每次寫入數據都刷新到相應設備  
  16. uppercase =0x4000, //科學計數法的"e"和16進制計數的"x",大寫輸出為"E"和"X"  
  17. adjustfield =left | right | internal, //一般用作對齊方式的屏蔽碼  
  18. basefield =dec | hex | oct, //一般用作數值進制輸出方式的屏蔽碼  
  19. floatfield =scientific | fixed //一般用作浮點數輸出方式的屏蔽碼  
  20. };  

一般用派生類ios作前綴”ios::”使用以上枚舉值.

Setf函數的另一個使用原型如下:

Fmtflags setf(fmtflags flag,fmtflags mask)

其中第二個函數mask為隱碼格式.例如設置adjustfield,basefield和floatfield格式.組成隱碼格式的所有格式會首先被復位,然後用第一個參數flag去設置新格式.

對於setf函數設置的格式,可用unsetf函數進行復位.下面是他的原型,參數mask為所要復位的格式.

Void unsetf(fmtflags mask)

下面程序使用setf/unsetf函數對內建的cout流進行格式設置和復位.

  1. #include  
  2. using namespace std;  
  3. int main(void)  
  4. {  
  5. //科學計數方式顯示,大寫E  
  6. cout.setf(ios::scientific | ios::uppercase);  
  7. cout<<2006.5<  
  8. //下面的showpos不起作用,不會顯示出"+"號  
  9. cout.setf(ios::floatfield,ios::fixed | ios::showpos);  
  10. cout<<2006.5<  
  11. //顯示"+"號  
  12. cout.setf(ios::showpos);  
  13. cout<<2006.5<  
  14. return 0;  
  15. }  
  16.  

對於流的其他格式,如輸出的最小寬域、數值精度以及填充字符的格式設置,可以使用ios_base類提供的width和precision函數,以及ios類提供的fill函數.

Width函數用newwidth設置新的最小域寬,如果輸出不足以占滿整個域,會補充適當的前導空格或者前導0.

Streamsize width(streamsize newwidth)

默認的數值精度為6位有效數字,可用precision函數將參數newprecision設置為新的精度值,數值輸出時會按這個精度進行必要的四捨五入.

Streamsize precision(streamsize newprecision)

默認的填充字符為空格字符,可以用fill函數將參數fill_char字符設置為填充字符

Char_type fill(char_type fill_char)

下面示例程序對cout流進行了域寬、精度和填充字符等流格式進行了設置。

  1. #include  
  2. using namespace std;  
  3. int main(void)  
  4. {  
  5. cout.width(20);  
  6. cout<<"hello"<  
  7. cout.precision(4);  
  8. cout<<2009.228<  
  9. cout.precision(5);  
  10. cout<<2009.228<  
  11. cout.precision(7);  
  12. cout<<2009.228<  
  13. cout.width(20);  
  14. cout.fill('*');  
  15. cout<<"baby"<  
  16. return 0; 

本文從C++流的概念和輸入輸出格式控制的方法,兩方面簡單的介紹了C++流,也就是我們經常說的I/O流。希望能對讀者有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved