double 转换long 丢失精度
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了double 转换long 丢失精度相关的知识,希望对你有一定的参考价值。
double d=2.01;
long f;
f=long(d*100.00);
结果得出f=200 请问怎么才能不丢失精度?
1楼2楼的 都不对
或者也可以自己去处理 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型超长自动转换精度丢失-JavaScript 整数精度丢失问题-springboot解决Long类型数据传入前端损失精度