成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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. C++之運算符重載,輸入輸出流詳細介紹
  2. 2.2.3 輸入輸出流
  3. C++標準輸入輸出應用技巧解析
  4. 3.2 組合輸入輸出流
責任編輯:于鐵 來源: 中國IT實驗室
相關推薦

2021-11-29 14:47:54

C++編程語言

2010-02-06 13:52:39

C++ profile

2013-07-29 04:37:53

iOS開發iOS開發學習NSLog輸出格式

2010-02-06 14:28:38

C++標準輸入輸出

2011-05-30 15:29:32

C++

2010-02-03 15:35:00

C++輸入輸出漢字

2010-01-28 13:27:12

C++類定義

2010-01-11 10:28:51

C++編程

2011-07-10 15:26:54

C++

2010-01-22 16:35:41

C++開發

2010-01-26 17:11:13

C++編程

2010-01-18 10:16:58

學習C++

2011-07-13 16:36:11

C++

2010-02-01 11:13:00

C++ Traits

2010-01-12 10:40:22

C++程序員

2010-01-22 15:53:55

C++轉換

2010-02-01 15:01:34

C++拋出異常

2010-01-12 10:11:36

學習C++語言

2024-08-16 14:15:00

AI訓練

2011-05-31 18:31:13

C++
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩av免费在线观看 | 亚洲三级在线观看 | 成人午夜在线 | 特一级毛片 | 欧美一区二区三区四区视频 | 久久aⅴ乱码一区二区三区 亚洲国产成人精品久久久国产成人一区 | 欧美激情五月 | 日韩欧美日韩在线 | 国产精品夜色一区二区三区 | 欧美xxxx色视频在线观看免费 | 黄一级| 国产精品国产a级 | 欧美精品区| 久久国产精99精产国高潮 | 精品国产高清一区二区三区 | 久久合久久 | 中文字幕亚洲区一区二 | 精品伦精品一区二区三区视频 | 天天干精品 | 久久久久久久久久久高潮一区二区 | 91在线观看 | 日韩在线国产精品 | 国产一区| 大学生a级毛片免费视频 | 亚洲欧洲成人av每日更新 | 一区在线观看 | 超碰成人在线观看 | 亚洲二区视频 | 婷婷激情综合 | 一区二区三区在线观看视频 | 欧美视频一级 | 久久免费视频网 | 国产精品久久久久一区二区三区 | 亚洲国产福利视频 | 91视频久久久久 | 午夜小视频在线播放 | 欧美精品欧美精品系列 | 日本高清视频在线播放 | 亚洲一级视频在线 | 欧美一区二区小视频 | 国产精品视频在线播放 |