gpt4 book ai didi

java - 将转换应用于整数和浮点除法的结果 : what's going on here?

转载 作者:搜寻专家 更新时间:2023-10-31 08:18:05 26 4
gpt4 key购买 nike

我是初学者,有些东西对我来说意义不大。请能解释一下我哪里出错了。如果之前有人问过这个问题,我很抱歉。

这里小数点的存在意味着这些是使用浮点除法计算的。

System.out.println(1/3.0); // this prints: 0.3333333333333333
System.out.println(1.0/3); // this prints: 0.3333333333333333
System.out.println(1.0/3.0); // this prints: 0.3333333333333333

显然,下面是一个“截断整数除法”的例子。这对我来说似乎有点奇怪,但没关系。

System.out.println(1/3); // this prints: 0

是否可以这样说:“在下面的行中,(double) cast 被评估为第一个。它实际上是说:“将 1/3 视为 double - 不要使用截断整数除法。而是使用浮点除法。""

System.out.println((double)1/3); // this prints: 0.3333333333333333

下面,然而我们得到 0.0 - 这是怎么发生的?

System.out.println((double)(1/3)); // this prints: 0.0

好吧,也许额外的括号意味着 (1/3) 被评估为第一个。它使用截断整数除法进行评估,得到 0。然后应用 double 给我们 0.0 好的,这是有道理的

好吧,我们也许可以在这里提出一些通用规则:

规则 1:(双)表达式意味着首先应用(双)转换,然后计算表达式。

规则 2:(double) (expression) 表示计算表达式然后应用转换。太棒了!

因此在下一行中我们有:(int) 表达式,所以我想我们可以应用规则 1)。 (int) cast 被评估为第一个。它实际上是说:“将 1.0/3 视为一个 int - 不要使用像 double 那样多的内存。不要使用浮点除法,而是应用截断整数除法。”“所以我们有 0 对吗?不.

System.out.println((int)1/3.0); // this prints: 0.3333333333333333

好的,所以我们有 0.33333,因此 (int) 转换不会被评估为第一个。就好像它不存在一样。让我们提出第三条规则:

规则 3:(int) 表达式意味着完全忽略 (int) 转换,就像 (int) 甚至不存在一样评估表达式。

好的,将规则 3 应用于下面的行,我们有 (int) 但我们将忽略它。 1.0/3.0 用浮点除法求值,我们得到 0.3333333。成功!

System.out.println((int)1.0/3.0); // this prints: 0.3333333333333333

在下面的最后一行中,我们再次使用 (int) 但我们将忽略它。 (1.0/3) 使用浮点除法计算得到 0.3333333333 对吗?没有。

System.out.println((int)(1.0/3)); // this prints: 0

好吧,我现在很困惑。你能帮我解决这个问题吗?

最佳答案

Java 的语言解析规则基本上是根据其操作顺序 规则在您的代码中到处使用大量括号。了解 Java 认为括号在哪里将有助于您理解这种行为。当你说:

(double) 1 / 3.0

...这相当于说:

((double) 1) / 3.0

这意味着 1 被转换为 double ,而 3.0 自动成为 double ,因此您最终将进行浮点除法而不是整数除法。 (double) 1/3 也会发生同样的事情,因为除数是 double,所以即使被除数是 int,系统意识到你想做浮点除法。编译器不希望你失去精度,除非你特别要求,所以任何时候被除数或除数是double,它会做double部门

另一方面:

(int) 1 / 3.0

...等同于说:

((int) 1) / 3.0

在这种情况下,您是在告诉编译器它已经知道的事情:除数 (1) 是一个 int。然后你要求它除以 double 值 (3.0)。由于被除数是一个double,它将执行double除法。

如您所述,1/3 将产生零,因为这就是整数除法的工作原理并且两个数字都是整数。 1/(int)3.0 也会发生同样的情况,因为您要告诉编译器在除法之前将 3.0 转换为 int发生(如 1/((int)3.0))。

要记住的最后一点是 (int) 0.33 也将转换为 0,因为整数不能包含小数值。所以当你说 (int)(1.0/3) 时,你正在做 double 除法,但随后你将 double 转换为 int 之后,生成 0

关于java - 将转换应用于整数和浮点除法的结果 : what's going on here?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6949897/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com