BigInteger和BigDecimal,BigInteger实现了任意精度的整数运算,BigDecimal实现了任意精度的浮点数运算,并且这两个可以运算任意长度的数值(这是Integer和Decimal等做不到的,他们都有长度限制,例如Integer就是10亿)
那为什么要使用任意精度?
因为有的时候我们的计算对精度的要求比较高,而浮点等运算事达不到的,并且由于浮点数的存储及运算规上的规定,总是会出一些奇怪的问题,假设我们运行以下的代码:
你猜结果等于多少?是不是0.9?但是,真实的结果是:
???
那如果我们使用大数值来运算
结果就成了0.9
细心的你会发现,为什么不能直接“—“?这是因为Java语言的设计者没有给大数值类提供+—*%的重载,所以只能调用add/subtract/mulitiply/divide等方法进行加减乘除的运算
转载于:https://www.cnblogs.com/Fill/p/9205750.html