我正在开发一个实时应用程序,该应用程序使用BigDecimal处理不同货币和汇率的货币,但是我遇到了一些严重的性能问题,并且我想更改基本表示形式。

我一遍又一遍地读到,一种用Java表示货币的好而快速的方法是使用long存储美分(或任何要求的精度)。正如评论中所指出的那样,有一些带有包装器的库就可以做到这一点,例如JavaMoney的FastMoney。

这里有两个问题。

  • 将钱存放很长时间(或放在包装纸内)并保持其他所有内容(如汇率)翻倍是否总是安全的?换句话说,如果我执行Math.round(money * rate)(金钱为美分,汇率为双倍),我是否会遇到与将所有内容都翻倍的基本相同的问题?
  • FastMoney和许多其他库仅支持它们与原始类型之间的操作。如果我不能做profit.divide(investment)(都是FastMoney),我应该如何准确地表示某笔投资的回报。我想我的想法是将两个都转换为双精度然后除法,但这是不正确的,对吗?
  • 最佳答案

    您正在寻找的功能已经在JavaMoney库中实现。

    它有一个FastMoney类,可以执行long算术运算,这正是您所要求的。

    对于Java新开发者-为什么要长而不是加倍?

    Java中的浮点算术由于其实现而导致一些意外的精度错误。因此,不建议在财务计算中使用它。

    还要注意,这与long算术计算中的精度损失不同,这是由于小数部分没有长时间存储。可以在实现过程中通过将小数部分移动到另一多头(例如1.05-> 1美元和5美分)来防止这种情况。

    参考

  • A Quick Tutorial
  • Project Website
  • 10-05 18:06