double 转换long 丢失精度

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了double 转换long 丢失精度相关的知识,希望对你有一定的参考价值。

double d=2.01;
long f;
f=long(d*100.00);
结果得出f=200 请问怎么才能不丢失精度?
1楼2楼的 都不对

这是一个典型的精度丢失的问题,很常见,一个效率不高的有效办法,是先将double转成string,然后再转成long,做一个中转。

或者也可以自己去处理 IEEE 浮点数格式来转化。

double d = 2.01;
long f;
char buff[32];
sprintf( buff, "%.0f", d * 100.0 );
sscanf( buff, "%d", &f );
printf( "%d", f );
参考技术A 十进制数在保存到电脑以后可能会产生误差, 在
double d=2.01;
的时候误差就已经产生了.

常见的办法是补足误差, 比如精度不会到1e-6的话, 你可以这样补
f = long((d + 1E-6)*100.0);
参考技术B 直接d=d*100.00 输出就是201 强制转化为long型 我试试怎么都是200 参考技术C 如果你一定要这么处理的话

这个可以这样做

f=long(double(d*100.00));
参考技术D char tp[50];
long f=0;
int i,t;
scanf("%s",tp); //用tp数组保存d
for(i=0;tp[i];i++)
if(tp[i]!='.')
f=f*10+tp[i]-'0';

Spring Mvc Long类型传输到前端精度丢失

参考技术A 由于javascript的number类型问题,前端使用number接收后端的long类型时,后两位会变成00,导致前后端id不一致

将后端的Long类型,在json序列化时,返回的类型为string类型

使用注解

全局处理,添加 http message转换器

以上是关于double 转换long 丢失精度的主要内容,如果未能解决你的问题,请参考以下文章

前端获取Long类型精度丢失解决办法

BigDecimal精度丢失问题

java里面double 做乘法和加法会丢失精度嘛?

iOS数据解析精度丢失

浏览器响应数据long型超长自动转换精度丢失-JavaScript 整数精度丢失问题-springboot解决Long类型数据传入前端损失精度

delphi中双精度数据类型是否double