JVic Asked:2020-05-18 21:55:42 +0000 UTC2020-05-18 21:55:42 +0000 UTC 2020-05-18 21:55:42 +0000 UTC 如何存“钱”?浮动/双 772 我在接受采访时,他们问,“在什么类型的变量中存储资金更好,”他说Float,他们说,速度,仅此而已。- 被拒绝。没有听到“为什么”这个问题的答案。所以这就是为什么“钱”不能存储在Float? java 3 个回答 Voted Best Answer tutankhamun 2020-05-18T22:38:32Z2020-05-18T22:38:32Z 对于钱,一分钱很重要。金融部门任何重要人物的流失都是不可接受的。由于数字以二进制形式存储 - 几乎所有十进制非整数都没有小数点后的有限位数。由于我们无法在小数点后存储无限多的数字,因此部分数字会丢失。 一个简单的例子:将 5.1 转换为二进制 整数部分只有3位 5₁₀ = 1*2² + 0*2¹ + 1*2⁰ = 101₂ 这是小数... .1₁₀ = 0*2⁻¹ + 0*2⁻² + 0*2⁻³ + 1*2⁻⁴ + 1*2⁻⁵ + 0*2⁻⁶ + 0*2⁻⁷ + 1*2⁻⁸ + 1*2⁻⁹... 如果你只取小数点后的前 7 位数字(二进制),你得到的不是0.1,但是0.09375 补充:关于用于存储财务数据的适当类型(因为问题有一个 Java 标记 - 例如),正如评论和相邻答案中已经写的那样,有两种方法: 任意精度类型(例如 BigDecimal)。我没有查看源代码,但内部存储很可能以字符串或数字数组的形式出现; 整数基本类型(int 或 long)。同时,财务以不可分割的计量单位存储在变量中(这些并不总是美分/美分,在某些情况下,例如,应考虑这些单位的百分之一) 一如既往,选择应取决于任务的具体情况。任意精度类型的处理速度可能比原始类型慢,但就原始类型而言,我们需要“记住”我们在其中存储的内容,以便在上传到相邻系统时不会得到天文数字。 Anton Mukhin 2020-05-18T23:34:26Z2020-05-18T23:34:26Z 可能可以在不深入机器计算的复杂性的情况下介绍一些细节:) 在这里,我们仍然需要澄清将用钱执行哪些操作。 对于支付和转账——足够了long。总和本身是小单位。因为我们不支付十分之一美分/美分。那些。对于1 руб. 10 копеек,我们将枚举110。 您也可以存储在同一类型中。但是在需要进行计算时已经存在问题。例如,每月计算一定百分比。这是类型double/float,正如一些人指出的那样,由于浮点标准的微妙之处,它可能不准确。但是有一个很好的出路:有数字对象以整数形式存储所有值。更具体地说:两个整数值:作为大整数类对象的实数的尾数,以及类型的非负十进制指数int。Java这为class举了一个例子BigDecimal。我会把钱放在里面。 好吧,如果您深入计算,那么所有操作都有标准。例如,如果我们计算罚分,则向上取整: 如果罚分在 中1.123456 руб,我们得到1.13。一切都很简单。 如果有人发现我的回答有误,请指正。我刚刚进入财务结算交易。 Denis Vabishchevich 2020-01-09T19:45:15Z2020-01-09T19:45:15Z 每个人都可以决定将钱存放在哪里,但最稳定的版本是使用BigDecimal. 优点 已知的准确性和重要性 包括算术和比较 在 JDK、JDBC 等中受支持。 很棒的表演
对于钱,一分钱很重要。金融部门任何重要人物的流失都是不可接受的。由于数字以二进制形式存储 - 几乎所有十进制非整数都没有小数点后的有限位数。由于我们无法在小数点后存储无限多的数字,因此部分数字会丢失。
一个简单的例子:将 5.1 转换为二进制
整数部分只有3位
这是小数...
如果你只取小数点后的前 7 位数字(二进制),你得到的不是
0.1
,但是0.09375
补充:关于用于存储财务数据的适当类型(因为问题有一个 Java 标记 - 例如),正如评论和相邻答案中已经写的那样,有两种方法:
一如既往,选择应取决于任务的具体情况。任意精度类型的处理速度可能比原始类型慢,但就原始类型而言,我们需要“记住”我们在其中存储的内容,以便在上传到相邻系统时不会得到天文数字。
可能可以在不深入机器计算的复杂性的情况下介绍一些细节:)
在这里,我们仍然需要澄清将用钱执行哪些操作。
对于支付和转账——足够了
long
。总和本身是小单位。因为我们不支付十分之一美分/美分。那些。对于1 руб. 10 копеек
,我们将枚举110
。您也可以存储在同一类型中。但是在需要进行计算时已经存在问题。例如,每月计算一定百分比。这是类型
double/float
,正如一些人指出的那样,由于浮点标准的微妙之处,它可能不准确。但是有一个很好的出路:有数字对象以整数形式存储所有值。更具体地说:两个整数值:作为大整数类对象的实数的尾数,以及类型的非负十进制指数int
。Java
这为class举了一个例子BigDecimal
。我会把钱放在里面。好吧,如果您深入计算,那么所有操作都有标准。例如,如果我们计算罚分,则向上取整:
如果罚分在 中
1.123456 руб
,我们得到1.13
。一切都很简单。如果有人发现我的回答有误,请指正。我刚刚进入财务结算交易。
每个人都可以决定将钱存放在哪里,但最稳定的版本是使用
BigDecimal
.优点