在以有补码的概念下去理解该result
下面即测试和理解代码,最后以Integer包装类中MIN_VALUE,MAX_VALUE,toBinaryString()去验证
话不多说贴代码:
/**
* 以补码进行加运算
* -2147483648 的补码:1000 0000 0000 0000 0000 0000 0000 0000
* 补码+(-1的补码) -1的二进制补码:1111 1111 1111 1111 1111 1111 1111 1111
* 得到补码0111 1111 1111 1111 1111 1111 1111 1111,符号位为0为正数补码
* 正数原码=补码为0111 1111 1111 1111 1111 1111 1111 1111(即十进制2147483647)
*/
System.out.println(0x00000000); //result:0
System.out.println(0x80000000); //result:-2147483648
System.out.println(-2147483648-1);//result: 2147483647
System.out.println(0x80000000-1); //result: 2147483647
System.out.println(new Integer(0xffffffff)); //result:-1
System.out.println(0xffffffff);// result:-1 16进制转二进制为:1111 ...(6个1111) 1111
// result:-1 输出值为-1 证明即按补码形式输出指定正负数
System.out.println(0x7fffffff);// result:2147483647 转换为二进制位0111 1111 ...(6个1111)十进制值为result
System.out.println(Integer.MAX_VALUE); // result:2147483647
//由此可以看出在有符号的数据类型中,计算机中只有补码概念,用于存储和运算(可以是算术运算可以是位运算)只要都以补码去看问题去求解问题
//理解补码后,可以知道 Integer.MAX_VALUE+1 = Integer.MIN_VALUE
System.out.println(Integer.MAX_VALUE+1);// -2147483648
//当然我们可以输出该值补码的二进制
System.out.println(Integer.toBinaryString(Integer.MIN_VALUE));
//上条输出-2147483648的补码即result:10000000000000000000000000000000
System.out.println(Integer.toBinaryString(Integer.MAX_VALUE));
//上条输出即最大值2147483647的二进制补码:1111111111111111111111111111111(只有31个1,省列了符号位的0)
System.out.println(Integer.numberOfLeadingZeros(Integer.MAX_VALUE)); //result:1 说明最大值前还有1个0
//以-1测试输出-1的8进制和16进制
System.out.println(Integer.toOctalString(-1));
//输出的结果8进制为:37777777777 按每三位换数为二进制即为-1的二进制补码
System.out.println(Integer.toHexString(-1));
//输出的结果为16进制:ffffffff 换算为二进制即为-1的二进制补码 1111 ... 1111
以上仅为个人理解,有错望指正,谢谢。