java 里面的基本类型占用的储存空间及浮点类型数据的储存

我是一个小前端, 想学学 java 的思想用以加深自己对前端的学习, 如果错误请指正
关于数值类型的学习

储存单位

储存单位最小的单位是 bit(位)
1KB = 1024Byte
1Byte = 8bit
在这里插入图片描述

整型

类型大小范围等于的bit备注
byte1字节-(2^7) ~ ( 2^7 - 1)1*8这里的次方就是bit的个数, bit中有一个是用来储存正负符号的所以是7
short2字节-(2^15) ~ ( 2^15 - 1)2*8
init4字节-(2^31) ~ ( 2^31 - 1)4*8
long8字节-(2^63) ~ ( 2^63 - 1)8*8
BigInteger还没学习到这, 听一个同事说, 这个类型挺牛逼的

示例: 计算机的储存方式是二进制

数值储存方式
int 1 = 100000001
int 1 = 300000011

数值 1 在储存里是这样的
在这里插入图片描述

浮点类型

浮点一般用 double 来声明

类型大小范围等于的bit备注
float4字节-2^128 ~ 2^1284*8
double8字节-2^1024 ~ 2^10248*8

浮点数的存储方式:由符号位、指数位和尾数位三部分组成

  • 符号位
  • 指数位
  • 尾数部分
位置所在位数
符号位1
指数位`8
尾数部分23

十进制小数转为二进制采用 “乘2取整, 顺序排列”。具体做法是:用2乘十进制小数,可以得到积,将积的整数部分取出,再用2乘余下的小数 部分,又得到一个积,再将积的整数部分取出,如此进行,直到积中的小数部分为零,或者达到所要求的精度为止。

0.825 转为 二进制小数

0.825 * 2 = 1
0.625 * 2 = 1
0.25 * 1 = 0
0.5 * 2 = 1 

// 0.1101

将 0.1101 转为 二进制的科学计数位 1.101 * 2 ^-1
符号位等于 0
指数位等于 127 - 1 = 126 = 0111 1110
尾数为等于 101, 补全23 位 10100000000000000000000 (就是小数位后面的)
结果 0 0111 1110 10100000000000000000000

位置
符号位0
指数位0111 1110
尾数部分10100000000000000000000

173.8125 = 10101101.1101
转为科学计数法 1.01011011101 * 2^7
符号位等于 0
指数位等于 127 + 7 = 134 = 1000 0110
尾数为等于 01011011101, 补全23 位 01011011101000000000000 (就是小数位后面的)
结果 0 1000 0110 01011011101000000000000

位置
符号位0
指数位1000 0110
尾数部分01011011101000000000000

十进制转二进制
在内存的展示方式

小记

  1. 科学计数法: 7.1602143299E+06; 这串数字的意思是 7.1602143299 * 10^6
  2. 参考博客
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值