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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • pyspark.sql模块 模块上下文 Spark SQL和DataFrames的重要类: pyspark.sql...
    mpro阅读 13,143评论 0 13
  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 9,675评论 0 13
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,328评论 19 139
  • 五月清晨的阳光洒在窗台,洒在我们的笑容里,满是盛夏的味道。 启一曲轻柔的音乐,伴着聂老师的低语指引...
    xuyao阅读 1,534评论 0 1
  • 金乌烹六月,火鸟涅槃时。桑梓殷殷盼,椿萱切切期皋城红掌早,淠水紫薇迟。莫作轻浮语,凉秋桂一枝。 (注:金乌指太阳,...
    风雪莘阅读 3,379评论 0 0