3.2.2 for循环的变体(5)

2013-10-07 16:07:11 · 作者: · 浏览: 63

3.2.2  for循环的变体(5)

2. 浮点循环计数器

还可以使用浮点数作为循环计数器。下面的for循环示例就使用了这种计数器:

  1. double a(0.3), b(2.5);  
  2. for(double x = 0.0; x <= 2.0; x += 0.25)  
  3. cout << "\n\tx = " << x 
  4. << "\ta*x + b = " << a*x + b; 

该代码段计算a*x+b的值,x的值以0.25为步长从0.0增加到2.0,但我们需要注意何时在循环中使用浮点计数器。许多小数值不能以二进制浮点形式精确表示,因此累积数值时可能产生误差。这意味着for循环的结束不应该取决于浮点循环计数器达到某个精确值。例如,下面这个设计拙劣的循环将永远不会结束。

  1. for(double x = 0.0 ; x != 1.0 ; x += 0.1)  
  2. cout << x

该循环的意图是随着x从0.0变化到1.0,输出该变量的值,但0.1不能精确表示成二进制浮点数,这样x的值就永远不会精确等于1。因此,第二个循环控制表达式始终为false,这样该循环将无限继续下去。

很容易看出为什么一些十进制的小数值不能精确地表示为二进制值。在二进制的小数部分,小数点右边的数字等价于1/2、1/4、1/8/、1/16等的十进制小数部分。因此十进制的小数部分总是上述一个或多个分数之和。1/3或1/10等这样具有古怪分母或古怪分子的十进制小数,永远不能精确地表示为分母为偶数的分数之和。