和
printf("%lf\n",-1.0+0.9+0.1);
结果是
0.000000
同时与
cout<<-1.0+0.9+0.1;
结果是
2.77556e-17
再次,如果我改变
cout<<0.9+0.1+-1.0;
结果是
0
为什么这种不同的行为只是简单地反转总和?为什么 2.77556e-17?它是机器 epsilon?为什么我得到它而不是零?
std::cout
默认情况下,浮点变量类似于标志%g
而不是. 为了获得相同的行为,您必须传递给流,例如:%lf
printf
std::fixed
std::cout << std::fixed << 0.9+0.1+-1.0;