美文网首页
8.Double类源码解析

8.Double类源码解析

作者: CNCF | 来源:发表于2018-08-13 14:21 被阅读0次

    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方法。

    相关文章

      网友评论

          本文标题:8.Double类源码解析

          本文链接:https://www.haomeiwen.com/subject/wabybftx.html