Java中出现超出数据类型取值范围情况输出的值是什么?

要想弄清楚这件事情,我们先来认识一下什么是补码、原码和反码:

计算机中的符号数有三种表示方法,即原码、反码和补码。

三种表示方法均有符号位数值位两部分,符号位都是用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,变量溢出的值都在其补码中可以找到,且都满足以上代码的规律。当涉及到强制类型转换的时候,其值永远可以在取值范围较小的数据类型的补码中找到。

你可能感兴趣的:(Java)