打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
double类型与零值比较时不能用==和!=
可以用>=和<=进行比较的。
浮点数(double)之所以不能用 == 和 != 是因为浮点数在内存中都是按精度来存储的,所以你看到的 3.12也许本来是3.123456取的小数点后2位位精度,所以当与另一个 3.12进行比较时可能会出现很多种情况,如果另一个3.12其实是3.121111取的小数点后2位位精度的话,那么两个数你看着相等,其实是不等的。
所以你办在对浮点数进行比较的时候一般都是相减然后去和一个精度比较。
例如:
a=3.12; b=3.13;
当a和b比较时就应该:
#define N 0.0001
if(a-b<N)
就说明a小于b;.
而不是直接去比较 if( a<b)

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
float与double的范围和精度_本为贵公子,平生实爱才
单精度浮点数(float)与双精度浮点数(double)的区别
浮点变量与零值比较
什么是浮点数?
java四类八种基本数据类型
C#中对于float,double,decimal的误解
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服