问题描述
我可以很容易地一目了然地将2e15读成"两千万亿",但对于2000000000000000,我必须计算零,这需要更长的时间,可能会导致错误。
为什么不能使用文字声明int或long,如2e9或1.3e6?我知道10的负幂(如2e-3)或小于小数位数的10的幂(如1.0003e3)会产生浮点数,但为什么Java不允许这样的声明,而只是截断浮点部分,并在结果值不是整数的情况下发出温和警告?这是一个糟糕的主意,有没有技术原因,或者这完全是类型安全的问题?对于编译器来说,简单地解析像
这样的语句不是很简单吗long x = 2e12ASlong x = 2000000000000 //OK for long
和int y = 2.1234e3ASint y = 2123.4 //warning: loss of precision
推荐答案
因为当您使用科学记数法时,您将创建a floating point number(在您的示例中为双精度)。并且不能将浮点赋给整数(这将是缩小基元转换,which is not a valid assignment conversion)。
因此这也不起作用,例如:
int y = 2d; //can't convert double to int
您有几个选项:
- 将浮点显式转换为整数:int y = (int) 2e6;
- 在Java 7+中使用千分隔符:int y = 2_000_000;