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

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日

悬赏问题

  • ¥15 对于这个问题的解释说明
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败
  • ¥15 树莓派5怎么用camera module 3啊
  • ¥20 java在应用程序里获取不到扬声器设备