函数
<ios> <iostream>

std::fixed

ios_base& fixed (ios_base& str);
使用定点表示法
str 流的 floatfield 格式标志设置为 fixed

floatfield 设置为 fixed 时,浮点值将使用定点表示法写入:值表示为十进制部分具有由精度字段precision)指定的位数,并且没有指数部分。

floatfield 格式标志是选择性标志和切换标志:它可以具有以下一个、多个或零个值

标志值设置时的效果
fixed以定点表示法写入浮点值
scientific以科学表示法写入浮点值。
(无)以默认浮点表示法写入浮点值。
默认表示法(无)fixedscientific 是不同的 floatfield 值。可以通过调用 str.unsetf(ios_base::floatfield) 来选择默认表示法。

对于标准流,在初始化时没有设置 floatfield(默认表示法)。
floatfield”格式标志既是选择性标志,也是切换标志:它可以接受以下任何值,或者不接受任何值

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

对于标准流,初始化时 floatfield 格式标志被设置为 defaultfloat

精度字段可以通过成员 precision 进行修改。

请注意,精度字段在默认浮点表示法以及 fixed 和 scientific 表示法之间的处理方式不同(请参阅 precision)。在默认浮点表示法中,精度字段指定小数点前后有意义的数字的最大位数,而在 fixed 和 scientific 表示法中,精度字段精确指定小数点后要显示的位数,即使它们是尾随零。

参数

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

返回值

参数 str

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// modify floatfield
#include <iostream>     // std::cout, std::fixed, std::scientific

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

  std::cout.precision(5);

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

  std::cout << '\n';

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

  std::cout << '\n';

  std::cout << "scientific:\n" << std::scientific;
  std::cout << a << '\n' << b << '\n' << c << '\n';
  return 0;
}

可能的输出
default:
3.1416
2006
1e-010

fixed:
3.14159
2006.00000
0.00000

scientific:
3.14159e+000
2.00600e+003
1.00000e-010


数据竞争

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

异常安全

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

另见