函数
<ios> <iostream>

std::defaultfloat

ios_base& defaultfloat (ios_base& str);
使用默认的浮点数表示法
将流 strfloatfield 格式标志设置为 defaultfloat

floatfield 设置为 defaultfloat 时,浮点数值将使用默认表示法写入:表示法最多包含流的小数精度precision)所需的有效数字,包括小数点(如果存在)前后的数字。

floatfield”格式标志既是选择性标志,也是切换标志:它可以接受以下任何值,或者不接受任何值

标志值设置时的效果
fixed以定点表示法写入浮点值。
scientific以科学计数法写入浮点值。
hexfloat以十六进制格式写入浮点值。
此值与 (fixed|scientific) 相同
defaultfloat以默认浮点表示法写入浮点值。这是默认值(与无值相同,在设置任何其他 floatfield 位之前)。

对于标准流,floatfield 格式标志在初始化时设置为此值(defaultfloat)。

参数

str
受影响的 floatfield 格式标志的流对象。
因为此函数是一个操纵符,它被设计为在不带参数的情况下,与流上的插入 (<<) 和提取 (>>) 操作结合使用(见下例)。

返回值

参数 str

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
// hexfloat floatfield
#include <iostream>     // std::cout, std::hexfloat, std::defaultfloat

int main () {
  double a = 3.1415926534;
  double b = 2006.0;
  double c = 1.0e-10;

  std::cout.precision(5);

  std::cout << "hexfloat:\n" << std::hexfloat;
  std::cout << a << '\n' << b << '\n' << c << '\n';

  std::cout << '\n';

  std::cout << "defaultfloat:\n" << std::defaultfloat;
  std::cout << a << '\n' << b << '\n' << c << '\n';

  return 0;
}

可能的输出
hexfloat:
0x1.921fb5p+1
0x1.f58000p+10
0x1.b7cdfep-34

defaultfloat:
3.14159
2006
1e-010


数据竞争

修改 str。对同一个流对象的并发访问可能导致数据竞争。

异常安全

基本保证:如果抛出异常,str 处于有效状态。

另见