黑马程序员技术交流社区
标题:
一个有趣的现象 求深入解释你 深入!!
[打印本页]
作者:
Nero
时间:
2013-9-3 11:33
标题:
一个有趣的现象 求深入解释你 深入!!
本帖最后由 Nero 于 2013-9-3 11:34 编辑
byte b = 127; b = b += 1;
System.out.println(b);// 输出为-128;
byte c = -128; c = c -= 1;
System.out.println(c);// 输出为127;
//问 byte 是一个“环”吗 请深入解释~
复制代码
其他类型的整形变量是不是也是一样的现象???
作者:
焦允
时间:
2013-9-3 11:56
楼主理解的没错,整数类型的数据在做这样的运算的时候,确实存在这样一个规律,请看下面的图解:
2147483647 1(2).png
(16.59 KB, 下载次数: 19)
下载附件
整型数据运算中的循环
2013-9-3 11:51 上传
上面一行是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