.Yxh 2022-03-17 23:29 采纳率: 100%
浏览 67
已结题

Java基础,float转double


public class FuDian {
    public static void main(String[] args) {
        float f=10.1f;
        double d=(double) f;
        System.out.println(d);
    }
}

我想把变量f赋值给double变量d得出来的结果是:10.100000381469727
所以为什么10.1转成double不是10.100000000000000而出现了381463727

  • 写回答

5条回答 默认 最新

  • CSDN专家-sinJack 2022-03-17 23:36
    关注

    因为是浮点型,容易出现精度丢失。
    计算机中计算是转为二进制数进行运算的。
    而十进制的小数,二进制表示有时不够精确。浮点数值没办法用十进制来精确表示的原因要归咎于CPU表示浮点数的方法。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 3月26日
  • 已采纳回答 3月18日
  • 创建了问题 3月17日