为什么Java的部门被打破了?

时间:2016-12-08 07:28:49

标签: java division

我是一位经验丰富的php开发人员,刚刚开始学习Java。我现在正在学习一些Lynda课程,而且我还处于早期阶段。我正在编写请求用户输入的示例程序,并进行简单的计算和处理。

昨天我遇到了这种情况:

double result = 1 / 2;

凭借我的穴居人脑,我会想result == 0.5,但不是,不是用Java。显然1 / 2 == 0.0。是的,我知道如果我将其中一个操作数更改为double,结果也将是双倍。

实际上,这吓到我了。我无法帮助,但认为这是非常破碎的。认为整数除法产生整数是非常天真的。我认为情况很少。

但是,由于Java被广泛使用并且正在搜索“为什么Java的分裂被破坏了?'不会产生任何结果,我可能错了。

我的问题是:

  1. 为什么除法表现得像这样?
  2. 我还能在哪里找到这样的魔法/伏都教/意外行为?

6 个答案:

答案 0 :(得分:5)

Java是一种强类型语言,因此您应该了解表达式中值的类型。如果不是......

1int2),因此1/2是1和2的整数除法,因此结果为0 int。然后结果将转换为相应的double值,因此0.0

整数除法与浮点除法不同,如数学(自然数除法不同于实数除法)。

答案 1 :(得分:3)

您正在考虑像PHP开发人员; PHP是dynamically typed语言。这意味着类型是在运行时推导出来的,因此分数不能在逻辑上产生整数,因此从除法运算中暗示double(或float)。

Java,C,C ++,C#和许多其他语言都是strongly typed种语言,所以当一个整数除以一个整数后,你得到一个整数,100/50会让我回到2 ,就像100/45给我2一样,因为100/45实际上是2.2222...,截断小数以获得整数(整数除法),然后得到2

在强类型语言中,如果您希望结果符合预期,则需要显式(或隐式),这就是为什么在除法运算中将一个参数设为double或float将导致浮点除法(给出后面的分数)。

因此在Java中,您可以执行以下操作之一来获取小数:

double result = 1.0 / 2;
double result = 1f / 2;
double result = (float)1 / 2;

从松散类型的动态语言转变为强类型的静态语言可能会让人感到不安,但是没有必要害怕。只需了解除了输入之外你必须特别注意验证,还必须验证类型。

从PHP到Java,你应该知道不能做这样的事情:

$result = "2.0";
$result = "1.0" / $result;
echo $result * 3;

在PHP中,这将产生输出1.5(自(1/2)*3 == 1.5起),但在Java中,

String result = "2.0";
result = "1.0" / result;
System.out.println(result * 1.5);

这会导致错误,因为你不能分割字符串(它不是数字)。

希望可以提供帮助。

答案 2 :(得分:0)

我绝不是这方面的专业人士,但我认为这是因为如何定义运算符来进行整数运算。 Java使用整数除法来计算结果,因为它看到两者都是整数。它需要作为这个" division"的输入。方法两个整数,并且除法运算符被重载,并执行该整数除法。如果不是这种情况,那么Java每次都必须在重载方法中执行转换为double,如果你可以先执行转换,这实际上是无用的。

答案 3 :(得分:0)

如果你用c ++试试,你会看到结果是一样的。 原因是在将值赋给变量之前,您应该计算它。您键入的数字(1和2)是整数,因此它们的内存分配应该是整数。然后,划分应该按照整数来完成。之后,它会将其转换为double,这会得到0.0

答案 4 :(得分:0)

  

为什么除法表现得像这样?

因为语言规范以这种方式定义它。

  

我还能在哪里找到这样的魔法/伏都教/意外行为?

由于你基本上称之为“魔术/伏都教”的东西在语言规范中得到了完美的定义,答案是“无处不在”。

所以问题实际上是为什么在Java中有这个设计决定。从我的观点来看,导致int的{​​{1}}除法对于强类型语言来说是完美合理的设计决策。经常会使用纯int算术,因此intint中的float除法结果会产生,您需要进行大量舍入,这样做不会很好。< / p>

答案 5 :(得分:-1)

package demo;

public class ChocolatesPurchased
{
    public static void main(String args[])
    {
        float p = 3;
        float cost = 2.5f;
        p *= cost;
        System.out.println(p);
    }
}