《C++ Primer》第五版,中文版。p33。
1.999999999999999(比转换之后少是 2 的少个 9) 也是 1。
微软免费 IDE 2015。g++ 好像也一样。
#include <iostream>
using namespace std;
int main()
{
double d = 1.9999999999999999;
int i = d;
cout << i << endl;
return 0;
}
《C++ Primer》第五版,中文版。p33。
1.999999999999999(比转换之后少是 2 的少个 9) 也是 1。
微软免费 IDE 2015。g++ 好像也一样。
#include <iostream>
using namespace std;
int main()
{
double d = 1.9999999999999999;
int i = d;
cout << i << endl;
return 0;
}
强制转换int是转换为不大于这个数字的最大整数,所以1.9转化为1。
1.999999999999999因为存在精度误差,编译后其实已经超过2了,所以结果是2。浮点数存在表示误差和进制转换误差。