8.Double类源码解析
1.
double把 1.0/0.0 作为无穷大,-1.0/0.0为负无穷大,NaN是为了后面 isNaN函数做准备,判断一个数是不是NaN,其实现都是通过上述 v != v 的方式,因为NaN是唯一与自己不相等的值,NaN与任何值都不相等。MAX_VALUE与MIN_VALUE 指的是最大值,最小值。MIN_NORMAL 博主没查到,欢迎留言,MAX_EXPONENT和MIN_EXPONENT是正负的精度,SIZE大小,BYTES指的是一个double有几个byte组成,TYPE 应该是给包装类型准备的,序列化id 就不说 了。还有一个value 指的是double具体的值
2.
两个构造函数,第一个直接返回value,第二个实际上调用了FloatingDecimal的parseDouble方法,这里不再深入下去了。很多方法都依赖于FloatingDecimal 这个类
3.
toString 调用的还是FloatingDecimal类中的方法。
4.
转成16进制字符串double 形式,先调了二个方法,判断了一下是否是又穷的double类型,不是直接toString,如果是则往下走,有一个Math.copySign ,这个方法实际上是看这个数是正的还是负的,如果是负的就加一个“-”,然后不管是正是负都加一个“0x” 表示16进制的前缀,然后做一次判断是否小于最小正标准值,如果是则拼接 “0.” 否则拼接“1.0”,然后会做一次截断,最长12位,然后返回。
5.
都是获取double 类型实例,这两个方法都优于构造函数Double(double).
6.
可以看做是一种类型,我们上面有提到,这个东西是唯一一种自己不等于自己的。
7.
是否是无限的。
8.
都是调之前讲过的方法,不多介绍了
9.
做一次转化返回即可。
10.
获取hashCode 一层套一层,我都取出来了,可以看到底层doubleToRawLongBits的方法调用的是navive方法,采用位移的方式获取hashCode
11.
调用的是doubleToLongBits 上一个方法我们已经看过底层还是比较的是value的值。
12.
调用的是native方法。
13.
比较方法,可能会出现NaN的情况,前面比较完之后,又调用了doubleToLongBits 方法
14.
sum直接加,最大值和最小值,调用了math的min和max方法。