.Yxh 2022-03-17 15: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 15:36
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    m明月Java3 2022-03-17 15:54

    是的

    回复
    CSDN专家-sinJack 2022-03-17 16:06

    有帮助,望点击我评论上方【采纳该答案】按钮支持一下,有问题继续沟通交流。

    回复
查看更多回答(4条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 3月25日
  • 已采纳回答 3月18日
  • 创建了问题 3月17日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部