[八]基础数据类型之Double详解
程序员文章站
2022-04-26 12:46:22
java中double 包装类Double简介 属性方法以及内部实现 Double方法解读 ......
double 基本数据类型double 的包装类
double 类型的对象包含一个 double 类型的字段
属性简介
用来以二进制补码形式表示 double 值的比特位数 | public static final int size = 64; |
二进制补码形式表示 double 值的字节数 | public static final int bytes = size / byte.size; |
表示基本类型 double 的 class 实例 | public static final class<double> type = (class<double>) class.getprimitiveclass("double"); |
能够表示的最大值 只有标准化一种形式,也就是前文提到过的 |
public static final double max_value = 0x1.fffffffffffffp+1023; |
标准化的最小值 |
public static final double min_normal = 0x1.0p-1022; |
最小值还有非标准化的形式 |
public static final double min_value = 0x0.0000000000001p-1022; |
正无穷 等同于double.longbitstodouble(0x7ff0000000000000l) |
public static final double positive_infinity = 1.0 / 0.0; |
负无穷 等同于double.longbitstodouble(0xfff0000000000000l). |
public static final double negative_infinity = -1.0 / 0.0 |
nan not a number 等同于double.longbitstodouble(0x7ff8000000000000l) |
public static final double nan = 0.0d / 0.0 |
指数真值的有效的最大值 | public static final int max_exponent = 1023 |
指数真值的有效的最小值 | public static final int min_exponent = -1022 |
这些属性,看过浮点数简介的话,可以很清晰的理解,再次说明下,但凡本人的系列文章,全部都是有顺序的
构造方法
double 依然提供了根据基本类型double以及double的string形式构造
string形式依然借助于parsexxx形式 parsedouble
double(double value) | |
double(string s) |
常用方法
对于浮点数,有一些额外的属性方法
我们浮点数介绍中,对于浮点数的表示形式进行了介绍
double提供了对于指定值的表示形式的获取方法, 这表示形式也就是是一个64位的二进制位序列
double
获取表示形式 对于获取表示形式 提供了两种形式的方法,主要是针对于非数字的nan的不同表示 他们可以与longbitstodouble 可以进行互相转换
|
||||
longbitstodouble(long) 返回对应于给定位表示形式的 double 值 如果参数是 0x7ff0000000000000l,则结果为正无穷大
如果参数是 0xfff0000000000000l,则结果为负无穷大
如果参数值在 0x7ff0000000000001l 到 0x7fffffffffffffffl 之间或者在 0xfff0000000000001l
到 0xffffffffffffffffl 之间,则结果为 nan
|
浮点数有几种特殊的表示,比如 无穷 nan等
额外的,也提供了一些相关的方法
static boolean isnan(double v) | 静态方法 是否一个非数字 (nan) 值 非数值 true |
static boolean isfinite(double d) | 静态方法 是否是有限的浮点数 有限的true |
static boolean isinfinite(double v) | 静态方法 是否是无穷大 是无穷大 true |
boolean isinfinite() | 实例方法 依赖静态方法 |
boolean isnan() |
实例方法
依赖静态方法
|
比较
static int compare(double d1, double d2) | 静态方法 比较两个double d1 < d2 小于0 d1 = d2 等于0 d1 > d2 大于0 |
int compareto(double anotherdouble) | 实例方法 两个对象进行大小比较,依赖于静态方法 |
parsexxx系列
字符串解析 为 基本类型,
不需要对象,所以都是静态方法
返回一个字符串形式表示的基本类型double 表现效果同valueof(string),不过valueof 返回的是对象 |
如果不包含可以解析的字符串将会抛出异常 |
底层依赖sun.misc.floatingdecimal |
valueof系列
把基本基本类型 包装为对象
用来创建获得对象,所以无需对象,全都是静态方法
不同于之前介绍的整数 数值,他们都有缓冲
double v不存在缓存,valueof也是直接new 对象
static double valueof(double d) | |
static double valueof(string s) | 依赖parsedouble方法 所以上面说跟valueof(string)表现效果相同,本身就是一样 |
double没有 decode方法
xxxvalue系列
类似之前介绍的其他数值类型 全部都是强转内部的 value return (xxx)value; |
bytevalue()
shortvalue()
intvalue()
longvalue()
floatvalue()
doublevalue()
|
tostring toxxxstring 系列
tostring(double)
tostring()
tohexstring(double)
static string tostring(double d) | 静态方法 |
string tostring() | 实例方法 内部调用 static string tostring(double d) |
static string tohexstring(double d) | 静态方法 返回 double参数的十六进制字符串表示形式 api帮助文档中对于字符的转换有明确的规定,可以仔细研究下 示例 |
tostring系列好像没什么好说的,又好像有很多要说的
用到的时候对于格式字符的规定有疑惑直接查看api
equals
boolean equals(object obj) |
将此对象与指定对象比较
当且仅当参数不是 null 而是 double 对象,且表示的 double 值与此对象表示的 double 值相同时,结果为 true
为此,当且仅当将方法 doubletolongbits(double) 应用于两个值所返回的 long 值相同时,才认为这两个 double 值相同
注意,在大多数情况下,对于 double 类的两个实例 d1 和 d2,当且仅当
d1.doublevalue() == d2.doublevalue()
为 true 时,d1.equals(d2) 的值才为 true
但是,有以下两种例外情况:
如果 d1 和 d2 都表示 double.nan,那么即使 double.nan==double.nan 值为 false,equals
方法也将返回 true
如果 d1 表示 +0.0 而 d2 表示 -0.0,或者相反,那么即使 +0.0==-0.0 值为 true,equals 测试也将返回 false
此定义使得哈希表得以正确操作
|
hashcode
static int hashcode(double value) | 静态方法 获得一个value的hashcode值 |
int hashcode() | 实例方法 依赖静态方法 |
其他方法
sum(double, double) | |
max(double, double) | |
min(double, double) |
总结
其实浮点数的表示形式与使用规范才是重点
就像float似的, double只是double的包装,double也只是ieee754
标准的一个实现,根本还是在于标准的理解
double 和 float
提供的方法结构基本上是一样的,毕竟都是浮点数,标准也都是ieee754
至此,已经介绍了,基本类型包装类中的数值部分
也就是byte short integer long float
double 他们作为数值有很多类似的方法
这些类似的方法属性也可以说是作为数值类型的共性
个人认为,找到共性能够更好理解运用 java提供的类与功能