繁体   English   中英

为什么双倍宽度= 50/110000;输出是0.000000000000000?

[英]Why double width = 50/110000; the output is 0.000000000000000?

这是我的代码:

double width = 50/110000;
System.out.println("width ori is "+width );

输出为: 0.00000000000

怎么了 ? 预期产量必须为4.5454545454545455E-4

任何人都可以向我解释原因吗?

因为你要划分两个整数,所以它只取整数部分(整数除法)。

在计算机程序中划分整数需要特别小心。 一些编程语言,处理整数除法(即通过给出整数商作为答案)。 所以答案是整数。

例子 :

In real life                  In Java

4/3  = 1.33333                4/3  = 1
25/12 = 2.083333              25/12 = 2
9/2 = 4.5                     9/2 = 4
50/110000 = 0.000454545       50/110000 = 0

您可以将其中一个(或两个但实际上没用)强制转换为double以避免:

double width = (double)50/110000;
double width = 50d/110000;
double width = 50.0/110000;

int/int结果返回一个integer

所以小数部分被截断,导致你得到一个整数

你需要施放:

double width = (double)50/110000;

正如@Josh M指出的那样,您也可以尝试:

double width = 50d / 110000d;

解释发生了什么:

在Java中,默认的数字类型是int ,因此当您编写50/110000 ,它们都被视为int ,尽管您将结果定义为double
int除法发生时,结果将为0 ,因为它们都是int ,然后double将保持这个值,它将表示为double ,因此你得到0.000000

可能的解决方案:

  • d50d/110000d编码这些数字。
  • 明确地施放一方(另一方将被隐式施放):( (double)50/110000
  • 50.0/110000

请参阅第5章转换和促销 ,它真的会对您有所帮助。

暂无
暂无

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

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