Why does integer division code give the wrong answer?(为什么整数除法代码给出错误的答案?)
问题描述
我在 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;
^
这篇关于为什么整数除法代码给出错误的答案?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么整数除法代码给出错误的答案?


- value & 是什么意思?0xff 在 Java 中做什么? 2022-01-01
- Jersey REST 客户端:发布多部分数据 2022-01-01
- Java包名称中单词分隔符的约定是什么? 2022-01-01
- 从 finally 块返回时 Java 的奇怪行为 2022-01-01
- Safepoint+stats 日志,输出 JDK12 中没有 vmop 操作 2022-01-01
- 如何使用WebFilter实现授权头检查 2022-01-01
- Eclipse 插件更新错误日志在哪里? 2022-01-01
- Spring Boot连接到使用仲裁器运行的MongoDB副本集 2022-01-01
- 将log4j 1.2配置转换为log4j 2配置 2022-01-01
- C++ 和 Java 进程之间的共享内存 2022-01-01