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