Java的数据类型


在这里插入图片描述
在这里插入图片描述

整形

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

浮点型

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二进制无法精确表示1/10

浮点数值不适用于无法接受舍入误差的金融计算中。 例如,命令 System.out.println( 2.0-1.1 ) 将打印出 0.8999999999999999, 而不是人们想象的 0.9。这种舍入误差的主要原因是浮点数值采用二进制系统表示, 而在二进制系统中无法精确地表示分数 1/10。这就好像十进制无法精确地表示分数 1/3—样。
举例:
在十进制的情况下:
123,相当于 1 × 10 2 + 2 × 10 1 + 3 × 10 0 1\times{10}^2 +2\times{10}^1+3\times{10}^0 1×102+2×101+3×100个位0,十位1,百位2

同理:1/10由二进制表示小数的时候只能够表示能够用 1 / ( 2 n ) 1/(2^n) 1/(2n)
例如:
0.5能够表示,因为它可以表示成为1/2
0.75也能够表示,因为它可以表示成为 1 / 2 + 1 / ( 2 2 ) 1/2+1/(2^2) 1/2+1/(22)
0.875也能够表示,因为它可以表示成为 1 / 2 + 1 / ( 2 2 ) + 1 / ( 2 3 ) 1/2+1/(2^2)+1/(2^3) 1/2+1/(22)+1/(23)

但是0.1不能够精确表示,因为它补能够表示成为 1 / ( 2 n ) 1/(2^n) 1/(2n)的和的形式
如果在数值计算中不允许有任何舍入误差,就应该使用 BigDecimal类。

字符型

字符型使用细节
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

布尔型

在这里插入图片描述

基本数据类型转换

自动类型转换

在这里插入图片描述

自动类型转换注意和细节

在这里插入图片描述

强制类型转换

自动类型转换的逆过程,将容量大的数据类型转换为容量小的数据类型。使用时要加上强制转换符 ( ),但可能造成
精度降低或溢出,格外要注意。
在这里插入图片描述

强制类型转换细节说明

在这里插入图片描述

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值