为什么整数除法代码给出错误的答案?

时间:2022-11-07
本文介绍了为什么整数除法代码给出错误的答案?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我在 Java 中有一个非常简单的除法(它是产品数量/每小时产量),但是每当我进行这种除法时,我都会遇到奇怪的错误:

I have a very simple division in Java (it's a product quantity / production per hour), however whenever I make this division I get strange errors:

float res = quantity / standard;

我用几个值尝试了上述除法,但总是出错,但是我在其他任何地方都尝试过并且正确的一个是:

I have tried the above division with several values and I always get errors, however the one that I've tried everywhere else and gotten right was this:

世界各地:

13.6 = 6800 / 500;

Java:

13.0 = 6800 / 500;

我研究过 BigDecimal 和 BigInteger,但是我还没有找到用它们创建这种除法的方法,有没有其他方法可以在 Java 中进行这种除法而不会出现精度错误??

I've researched BigDecimal and BigInteger, however I haven't found a way to create this division with them, is there any other way to do this division in Java without having precision errors??

任何帮助将不胜感激.

推荐答案

你正在对整数进行除法,这意味着你正在使用整数除法.

You're dividing integers, which means that you're using integer division.

在整数除法中,结果的小数部分被丢弃.

In integer division the fractional part of the result is thrown away.

尝试以下方法:

float res = (float) quantity / standard;
            ^^^^^^^

上面的内容强制将分子视为 float 反过来促进分母也浮动,并且执行浮点除法而不是整数除法.

The above forces the numerator to be treated as a float which in turn promotes the denominator to float as well, and a float-division is performed instead of an int-division.

请注意,如果您正在处理文字,则可以更改

Note that if you're dealing with literals, you can change

float f = 6800 / 500;

包含 f 后缀以使分母变为浮点数:

to include the f suffix to make the denominator a float:

float f = 6800f / 500;
              ^

这篇关于为什么整数除法代码给出错误的答案?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

上一条:将浮点数格式化为 n 位小数 下一条:为什么 Math.round(0.49999999999999994) 返回 1?

相关文章

最新文章