繁体   English   中英

为什么强制转换原始数据类型截断浮点值?

[英]Why casting of primitive data types truncate floating-point values?

基本类型的类型转换最常用于将浮点值转换为整数。 当我们这样做时,浮点值的小数部分会被截断。

public class Chaz {
            public static void main(String[] args) {
            double x = 1234.5678;
            long g = (long)x;
            System.out.println(g);
    }
}

从文档中

long数据类型是64位二进制补码整数。 带符号的long的最小值为-2 ^ 63,最大值为2 ^ 63-1

它不存储十进制精度值。 请看这里

long代表长整数。 我了解问题出在数据丢失,但是整数不能存储非整数。

可以决定存储数字的乘法,如下所示:

public class Chaz {
            public static void main(String[] args) {
            double x = 1234.5678;
            long g = (long)(x * 10000);
            System.out.println(g);
    }
}

然后知道g实际上是实际值的10000x。 或者,如果需要最接近的整数,则可以四舍五入。 我们不能没有其他信息而告诉我们,但实际上我们可以告诉我们,这是正常的和预期的行为。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM