m0_73268056 2024-04-12 23:19 采纳率: 0%
浏览 2

double d=81.7 int tem=(int)d/60 为什么会报错说不能把double转成int呢

double d=81.7
int tem=(int)d/60
为什么会报错说不能把double转成int呢
java

  • 写回答

3条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-04-12 23:19
    关注

    引自免费微信小程序:皆我百晓生

    在Java编程语言中,当你尝试将一个double类型的值转换为int类型时,并且这个double值不能被精确地表示为一个整数,就会发生数据溢出错误,因为浮点数到整数的转换会丢失小数部分。

    在这个例子中:

    double d = 81.7;
    int tem = (int) d / 60;
    

    首先,变量d被声明为double类型并赋值为81.7。然后,尝试通过强制类型转换(int)d转换为int类型。然而,在进行除法运算 / 60之前,你应该先将d转换为int,否则结果仍然是一个double类型。因此,你需要先将d转换为int,然后再执行除法操作。

    正确的做法是:

    double d = 81.7;
    int dAsInt = (int) d; // 将 double 转换为 int,会丢弃小数部分
    int tem = dAsInt / 60;
    

    这段代码中,dAsInt会存储81.7向下取整后的结果,即81。然后,将81除以60得到整数结果。这样就不会抛出错误了。

    如果你想要保留小数部分并且对结果进行处理(例如四舍五入),可以使用Math.round()函数:

    double d = 81.7;
    int tem = Math.round(d * 60) / 60;
    

    这里,我们先将d乘以60,然后使用Math.round()函数对结果进行四舍五入,再除以60得到最终的整数值。

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 4月12日

悬赏问题

  • ¥15 前端echarts坐标轴问题
  • ¥15 CMFCPropertyPage
  • ¥15 ad5933的I2C
  • ¥15 请问RTX4060的笔记本电脑可以训练yolov5模型吗?
  • ¥15 数学建模求思路及代码
  • ¥50 silvaco GaN HEMT有栅极场板的击穿电压仿真问题
  • ¥15 谁会P4语言啊,我想请教一下
  • ¥15 这个怎么改成直流激励源给加热电阻提供5a电流呀
  • ¥50 求解vmware的网络模式问题 别拿AI回答
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳