java 基础学习笔记—数据

JAVA 基础——数据

  1. ++运算:
    a++ 表达式值不变为a旧值,a值改变为+1;
    ++a表达式值加一,a值改变为+1。

  2. 关于原码,反码,补码的原理:
    这位博主写的十分详细深入
    关于原码,反码,补码的原理

  3. 关于数据转换:
    int x=3,y=5;
    float z;
    z=y/x (输出为1.0)
    z=(float)y/x (输出为1.66666) 注意这里(float)是对y进行强制转换而不是对 (y/x)强制转换
    z=(float)(y/x) 相当于对 (y/x)强制转换,结果与 z=y/x 相同为 1.0

  4. 关于引号的使用:
    字符类型使用单引号 char z=‘a’; 可以与 int 类型做算术运算相当于用 ascii 码值运算
    字符串类型使用双引号 String t=“str”;不可以与int类型做算术运算

  5. 关于float 和 double 是如何存储数据的:

float:4byte 32bit,1位符号位,8位指数位,23位尾数位。

double:8 byte 64bit,1位符号位,11位指数位,52位尾数位。

类型符号位指数位尾数位
float0000000000*23
double00*110*52

例如我们将17.625以float类型存储:

  • 第一步将整数位17转换为二进制:10001

  • 第二步将0.625转换为二进制,转换方法为 对小数位乘2,取整数位,舍弃整数位再循环直到小数位为0结束

    ​ 0.625*2=1.25 ------1

    ​ 0.25*2=0.5 ------0

    ​ 0.5*2=1.0 ------1

    所以17.625=10001.101

  • 将二进制表示成科学计算法:10001.101=1.0001101E(100),小数点向右移动了4位,相当于乘2的4次方,4表示成二进制就是100,因为科学计算法的整数位必然是1,所以我们尾数只要小数点后的即可,即尾数为0001101

    指数位就是100,正数符号位为0,负数符号位为1。

  • 存储尾数就是实际尾数直接放进去;存储指数为实际指数+127再放进去,这样做是为了保证指数位为正,指数位的八位就不需要再预留出符号位。

    实际指数00000100
    加上127+01111111
    存储指数10000011

    所以最后存储为:

    符号位指数位尾数位
    0100000110001101(后面省略了16个0)

double 存储与float存储唯一的区别就是存储指数=实际指数+1203

实际指数00000000100
加上127+01111111111
存储指数10000000011
符号位指数位尾数位
0100000000110001101(后面省略了45个0)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值