我是一个小前端, 想学学 java 的思想用以加深自己对前端的学习, 如果错误请指正
关于数值类型的学习
储存单位
储存单位最小的单位是 bit(位)
1KB = 1024Byte
1Byte = 8bit
整型
类型 | 大小 | 范围 | 等于的bit | 备注 |
---|---|---|---|---|
byte | 1字节 | -(2^7) ~ ( 2^7 - 1) | 1*8 | 这里的次方就是bit的个数, bit中有一个是用来储存正负符号的所以是7 |
short | 2字节 | -(2^15) ~ ( 2^15 - 1) | 2*8 | |
init | 4字节 | -(2^31) ~ ( 2^31 - 1) | 4*8 | |
long | 8字节 | -(2^63) ~ ( 2^63 - 1) | 8*8 | |
BigInteger | 还没学习到这, 听一个同事说, 这个类型挺牛逼的 |
示例: 计算机的储存方式是二进制
数值 | 储存方式 |
---|---|
int 1 = 1 | 00000001 |
int 1 = 3 | 00000011 |
数值 1 在储存里是这样的
浮点类型
浮点一般用 double 来声明
类型 | 大小 | 范围 | 等于的bit | 备注 |
---|---|---|---|---|
float | 4字节 | -2^128 ~ 2^128 | 4*8 | |
double | 8字节 | -2^1024 ~ 2^1024 | 8*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 |
小记
- 科学计数法: 7.1602143299E+06; 这串数字的意思是 7.1602143299 * 10^6
- 参考博客