关于10进制在内存中存储方式以及(byte)400、(byte)(400>>8)运算过程

10进制数在内存中存储涉及到原码,补码和反码的过程。

正整数以7为例,存储为00000000 00000000 00000000 00000111,正整数存储就无需过多的操作,负整数存储的话,内存中识别正负依靠的是最左边的数0为正,1为负,假设是-7,则需要逆向补码→取反过程,逆补码操作得到6,则取6的二进制后三位为110,补全前面则是00000000 00000000 00000000 00000000 00000110,取反后,加上标识最前面为1,则-7的二进制内存存储数为11111111 11111111 11111111 11111001。

存储函数图

在这里插入图片描述

	引入原码,补码和反码的概念

原码:假设机器字长为n,原码就是用一个n位的二进制数,其中最高位为符号位:正数是0,负数是1。剩下的表示概数的绝对值,位数如果不够就用0补全。
PS:正数的原、反、补码都一样,0的原码跟反码都有两个,因为这里0被分为+0和-0。
反码:在原码的基础上,符号位不变其他位取反,也就是就是0变1,1变0。 补码:在反码的基础上加1。

 (byte)400 运算过程

第一步:取400的二进制为110010000。
第二步:取后八位为,10010000,已知最前为作为标识,所以该数为负数。
第三步:取后7位,进行反码,得到结果1101111
第四步:转换为十进制为111,进行补码111+1,后为负数得到结果-112

 (byte)(400>>8)运算过程

位偏移符计算方式,<<n,左偏移乘以2的n次方,>>n,右偏移除以2的n次方,因此计算400右偏移8为1
int转byte 自然得出结果依然是1

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值