这是为什么回来的楠
Why is this returning nan?
代码:
double v = (180*9.8)/(42*42); // v should be 1.000000
printf("%f ",v);
cout<<asin(v);
输出:
1.000000
nan
我正在使用64位mingw(赢7(。
这是因为v大于1(当使用双精度浮点计算(180*9.8(/(42*42(时(。
double v = (180*9.8)/(42*42);
std::cout.precision(20);
cout << fixed << v << endl;
输出:
1.00000000000000022204
nan
演示
要解决有限精度的问题,可以执行以下操作。
if (v > 1)
v = 1;
if (v < -1)
v = -1;
9.8
是一个不能用浮点精确表示的值。也就是说,存储的实际值等于9.8 + delta
,其中delta
是一个小值,可以是正的也可以是负的。
如果delta
对您的浮点表示(可能是IEEE(是正的,那么180*9.8
将大于1764
,因此v
的值将超过1
。asin()
的唯一有效输入在-1
到1
的范围内。尽管没有为超出该范围的值指定asin()
的返回值,但NaN是报告该值的一种方式。
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 让NaN回来了,不知道为什么
- 这是为什么回来的楠
- 为什么回来不工作
- 为什么我通过串行发送的字节流(写入/dev/tty*)会重新映射回来