要想弄清楚这件事情,我们先来认识一下什么是补码、原码和反码:
三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位,三种表示方法各不相同。
在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一处理;同时,加法和减法也可以统一处理。
下面我们介绍原码是什么,以及如何求一个整数的原码,补码,反码。
1、 正整数的补码是其二进制表示,与原码相同
2、求负整数的补码,将其对应正数二进制表示所有位取反(包括符号位,0变1,1变0)后加1
注意!
数0的补码表示是唯一的。
[+0]补=[+0]反=[+0]原=00000000
[ -0]补=11111111+1=00000000
知道上面这些知识储备后:我们来考虑一下,当java中如果给一个变量超出其本身数据范围的值,会输出什么
byte number=127;//number的取值范围为-128---127,number的二进制码为 0111 1111
number++; //number+1,会使number的补码变为1000 0000此时number的值为-128(补码中第一位为符号位)
byte x=-128;
x--;//同理在x的补码1000 0000基础上-1,把补码当做二进制数看待,得到结果127
System.out.println(x);
System.out.println(number);
输出结果:
127
-128
当数据强制类型转换的时候
byte y;
int f=199;//f的值超出y的上限范围72(最大127)
y=(byte)f;
System.out.println(y);//输出的y的值为-128+71(72中有一个1是让127变为-128的)
输出结果
-57
经过尝试,当不涉及强制类型转换的时候,只要给变量赋予的值一次性不超过其最大上限+1,或者最低下限 -1,变量溢出的值都在其补码中可以找到,且都满足以上代码的规律。当涉及到强制类型转换的时候,其值永远可以在取值范围较小的数据类型的补码中找到。