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

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 17:27   4255   0

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

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

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

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP