Kim_zh

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
   1:   每个iostream对象维持一个控制IO格式化细节的格式状态。标准库定义了一组操纵符来修改对象的格式状态。所谓操纵符是可用作输入或输出操作符的函数或对象。iostream和iomanip头文件中分别定义了一些操纵符,如表所示:
   2:   
   3:  iostream中定义的操纵符
   4:   
   5:    boolalpha 将真和假显示为字符串 
   6:  * noboolalpha 将真和假显示为1, 0 
   7:    showbase 产生指出数的基数的前缀 
   8:  * noshowbase 不产生记数基数前缀 
   9:    showpoint 总是显示小数点 
  10:  * noshowbase 有小数部分才显示小数点 
  11:    showpos 显示非负数中的+ 
  12:  * noshowpos 不显示非负数中的+ 
  13:    uppercase 在十六进制中打印0X,科学记数法中打印E 
  14:  * nouppercase 在十六进制中打印0x,科学记数法中打印e 
  15:  * dec 用十进制显示 
  16:    hex 用十六进制显示 
  17:    oct 用八进制显示 
  18:    left 在值的右边增加填充字符 
  19:    right 在值的左边增加填充字符 
  20:    internal 在符号和值之间增加填充字符 
  21:    fixed 用小数形式显示浮点数 
  22:    scientific 用科学记数法显示浮点数 
  23:    flush 刷新ostream缓冲区 
  24:    ends 插入空字符,然后刷新ostream缓冲区 
  25:    endl 插入换行符,然后刷新ostream缓冲区 
  26:    unitbuf 在每个输出操作之后刷新缓冲区 
  27:  * nounitbuf 恢复常规缓冲区刷新 
  28:  * skipws 不为输入操作符跳过空白 
  29:    ws “吃掉”空白 
  30:   
  31:  注:带*的是默认状态。
  32:   
  33:  iomanip中定义的操纵符
  34:   
  35:  setfill(ch) 用ch填充空白 
  36:  setprecision(n) 将浮点精度置为n 
  37:  setw(w) 读写w个字符的值 
  38:  setbase(b) 按基数b输出整数 
  39:   
  40:  可以使用flags操作符恢复格式状态
  41:   
  42:  1、不带实参的flags()返回流的当前格式状态。返回值是名为fmtflags的标准库定义类型。
  43:   
  44:  2、flags(arg)接受一个实参并将流格式置为实参所指定的格式。
  45:   
  46:  Sample:
  47:   
  48:  void display(ostream& os) 
  49:  { 
  50:      //remember the current format state 
  51:      ostream::fmtflags curr_fmt = os.flags(); 
  52:      //do output that uses manipulators that change the format state of os 
  53:      os.flags(curr_fmt);    //restore the original format state of os 
  54:  } 
  55:   
  56:   
  57:   
  58:   
  59:   
  60:  使用举例:
  61:   
  62:  1、控制布尔值 boolalpha:
  63:  bool flag = flase;
  64:   
  65:  cout << flag << endl; //Display: 0
  66:   
  67:  cout << boolalpha << flag << endl; //Display: false
  68:   
  69:  2、控制整形 oct、hex:
  70:   
  71:  int ival = 16;
  72:   
  73:  cout << ival << endl; //Display: 16
  74:   
  75:  cout << oct << ival << endl; //Display: 20
  76:   
  77:  cout << hex << ival << endl; //Display: 10
  78:   
  79:      指出输出的基数及形式 showbase:
  80:   
  81:  cout << showbase; //Set format that showbase 
  82:  cout << ival << endl; //Display: 16 
  83:  cout << oct << ival << endl; //Display: 020 
  84:  cout << hex << ival << endl; //Display: 0x10
  85:   
  86:  cout << uppercase << hex << ival << endl; //Display:0X10
  87:   
  88:  cout << noshowbase; //Set the default format
  89:   
  90:  3、指定显示精度 precision setprecision
  91:   
  92:      默认情况下,精度控制显示的数字总位数。显示的时候,将浮点值四舍五入到当前精度。因此,如果精度为4,则3.1415926成为3.142。
  93:   
  94:  Sample:
  95:   
  96:      float pi = 3.1415926535; 
  97:      //cout.precision reports current precision value 
  98:      cout << cout.precision() << " " << pi << endl;    //Display: 6 3.14159 
  99:   
 100:      //one way to set format 
 101:      cout.precision(8); 
 102:      cout << pi << endl;    //Display: 3.1415927 
 103:      //another way to set format 
 104:      cout << setprecision(3) << pi << endl;    //Display: 3.14
 105:   
 106:  4、控制浮点数的记数法
 107:   
 108:      默认情况下,用于显示浮点值的记数法取决于数的大小,如果数很大或很小,将按科学记数法显示,否则,使用固定位数的小数。可以使用scientific或fixed来修改浮点数的默认记数法。但是要恢复默认记数法则必须调用unsetf成员来取消它们所做的改变。
 109:   
 110:      cout.unsetf(ofstream::floatfield); //reset to default handling for notation
 111:   
 112:  Sample:
 113:   
 114:      cout << sqrt(2.0) << endl;    //Dispaly: 1.41421 
 115:      cout << scientific << sqrt(2.0) << endl;    //Display: 1.414214e+00 
 116:      cout << fixed << sqrt(2.0) << endl;    //Display: 1.414214 
 117:      cout.unsetf(ostream::floatfield);
 118:   
 119:  5、填充输出 setw left right internal setfill:
 120:   
 121:      int i = -6; 
 122:      double d = 3.14159; 
 123:      cout << setw(12) << i << endl; 
 124:      cout << setw(12) << d << endl; 
 125:      cout << left << setw(12) << i << endl; 
 126:      cout << setw(12) << d << endl; 
 127:      cout << right; 
 128:      cout << internal << setw(12) << i << endl; 
 129:      cout << setw(12) << d << endl; 
 130:      cout << setfill('$') << setw(12) << i << endl; 
 131:      cout << setw(12) << d << endl; 
 132:      cout << setfill(' ');
 133:   
 134:  Display:
 135:   
 136:   
 137:   
 138:  5、控制输入格式化
 139:   
 140:      默认情况下, 输入操作符忽略空白。如:
 141:   
 142:  while(cin >> ch) 
 143:          cout << ch;
 144:   
 145:  给定输入序列:
 146:   
 147:  a b  c(分别为一个空格和两个空格)
 148:   
 149:  d
 150:   
 151:  循环执行四次从字符a读到d,跳过介于其间的空白。所以输出abcd.
 152:   
 153:  如果是:
 154:   
 155:      cin >> noskipws; 
 156:      while(cin >> ch) 
 157:          cout << ch; 
 158:      cin >> skipws;
 159:   
 160:  则同样的输入将输出:
 161:   
 162:  a b  c
 163:   
 164:  d

posted on 2013-12-01 16:56  Kim.zh  阅读(950)  评论(0编辑  收藏  举报