比较 float 是否相等
1. 为什么不是直接进行 == 比较而是需要写一个方法来进行比较?
因为 浮点数在计算计中的存储是通过二进制的方式进行存储会存在一个精度丢失的问题。
- 比如 :
浮点数
16777216的二进制为0-10010111-00000000000000000000000
浮点数 16777217 的二进制为 0-10010111-00000000000000000000000
所以两者相等.
- 具体原因可以参考文章 www.cnblogs.com/JoZSM/p/123…
2.工具类
const MIN = 0.000001
// IsEqual
// 判断 float 是否相等
func IsEqual(x, y float64) bool {
return math.Abs(x-y) < MIN
}