[英]Why are floating-point primitive types, when divided and multiplied by certain multiples of 10, are displayed in scientific notation?
[英]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
代表长整数。 我了解问题出在数据丢失,但是整数不能存储非整数。
可以决定存储数字的乘法,如下所示:
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.