Java中的Float范围
我一直在Java中尝试以下代码:
所以,以下是我得到的输出:
现在,我相信这是因为这扩大了浮动的范围但是当我读到这个时: 它显示浮动的包含范围:3.40282346638528860e 38 这让我很困惑. 编辑: 最佳答案
基本上,浮点值存储为一对尾数和指数.尾数描述了数字的有效数字(将其视为0到9.99之间的数字).指数是比例.您的号码显示为尾数* 2 ^ x.
我们正在谈论二进制系统中的表示,它使得偶数数字(在十进制系统中)像35912062那样可能不完全符合尾数的精度.在这些情况下,您会遇到一些舍入问题,尤其是浮点数对于尾数的范围相当有限. 使用double(而不是float)执行代码会得到3.5912062E7作为结果. 如果你真的想知道java(或浮点运算)对你的数字做了什么,你应该做System.out.println(new Bigdecimal(123.456))并感到惊讶. 这里的信息是,如果你真的需要精确的算术,总是需要BigDecimal.因为还有进一步的警告.例如,添加一个大的double和一个小的double可能会导致小的double被完全舍入.这让我们变得有趣:
永远不会终止.就试一试吧. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |