黑马程序员技术交流社区

标题: 一个有趣的现象 求深入解释你 深入!! [打印本页]

作者: Nero    时间: 2013-9-3 11:33
标题: 一个有趣的现象 求深入解释你 深入!!
本帖最后由 Nero 于 2013-9-3 11:34 编辑
  1. byte b = 127; b = b += 1;
  2. System.out.println(b);// 输出为-128;
  3. byte c = -128; c = c -= 1;
  4. System.out.println(c);// 输出为127;
  5. //问 byte 是一个“环”吗 请深入解释~
复制代码
其他类型的整形变量是不是也是一样的现象???
作者: 焦允    时间: 2013-9-3 11:56
楼主理解的没错,整数类型的数据在做这样的运算的时候,确实存在这样一个规律,请看下面的图解:
上面一行是int型数据的最大值二进制,加上1后,就变成了负数,也是int型数的最小值。其它的也是这个道理。

作者: EYE_SEE_YOU    时间: 2013-9-3 12:49
因为二进制位数限制的关系,会造成这样的问题,张孝祥老师的视频有提到过
作者: 第一印象    时间: 2013-9-3 13:37
嗯,对,其他类型确实也是一样的现象,如果一个数值类型的值到了它的正数的最大值,这时候再加1,就意味着最高位为1,而其他所有的位都变成0了,而最高位是一个符号位,1代表负数,0代表正数,所以会出现这样的情况,比如byte a = 127,这时候如果加1,就等于128了,但是byte类型是八个字节的,127的二进制是
0111-1111,加1后变成了1000-0000,等于128,但是最高位是1,所以是-128了,其他数值类型也是一样的道理




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2