• 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
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    将 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. 参考博客
  • 相关阅读:
    【零基础入门MyBatis系列】第十二篇——高级映射、延迟加载
    面试官:线程池中多余的线程是如何回收的?
    Oracle中LEFT JOIN后AND与WHERE的异同
    JavaScript的懒加载处理
    Docker:自定义镜像
    字节跳动面经——图形图像算法实习
    Transformer 模型
    C语言 ——— 学习、使用memcpy函数 并模拟实现
    目标检测算法——YOLOV7——详解
    筹备三年,自动驾驶L3标准将至,智驾产业链的关键一跃
  • 原文地址:https://blog.csdn.net/weixin_43191327/article/details/126568095