当前位置: 技术问答>java相关
为什么两个double类型的值相减,得不到正确的值,而是。。
来源: 互联网 发布时间:2015-09-05
本文导语: 为什么两个double类型的值相减,得不到正确的值,而是。。 double d1=11518.146; double d2=18961.7588; System.out.println(d2-d1); 得到的值是7443.612799999999 why? | doule的精度为15-16位 float的...
为什么两个double类型的值相减,得不到正确的值,而是。。
double d1=11518.146;
double d2=18961.7588;
System.out.println(d2-d1);
得到的值是7443.612799999999
why?
double d1=11518.146;
double d2=18961.7588;
System.out.println(d2-d1);
得到的值是7443.612799999999
why?
|
doule的精度为15-16位
float的精度为7-8位
好像是这样的,你不需要管后面的就行了
float的精度为7-8位
好像是这样的,你不需要管后面的就行了
|
恩,研究完毕~。那是 java 对 ieee 754 的逐渐下溢的支持~
|
楼主:
double类型和float类型数据都是有精度的,精度大约在6-7位,所以两个相加或者两个相减得到的数据其精度都在6-7位之间,后面的就不必在意了
double类型和float类型数据都是有精度的,精度大约在6-7位,所以两个相加或者两个相减得到的数据其精度都在6-7位之间,后面的就不必在意了
|
你的double类型的小数位不够多
您可能感兴趣的文章:
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。