1. //请教一个笔试题,:
2. public static void main(String[] args) {
3. // TODO Auto-generated method stub
4. int i= 0xFFFFFFFA;
5. int j=~i;
6. System.out.println(i);
7. System.out.println(j);
8. }
9. /*结果为什么是:
10. -6
11. 5
12. 为什么*/
Answer:
引用
int i= 0xFFFFFFFA;
最高位F对应的2进制表示为1111,int是带符号的整数,最高位为1表示是个负数,负数在电脑中用补码表示,那就要计算出0xFFFFFFFA的补码。
原码=1111 1111 1111 1111 1111 1111 1111 1010
补码=1000 0000 0000 0000 0000 0000 0000 0101 还要+1就等于
1000 0000 0000 0000 0000 0000 0000 0110
第一个1表示负数,后面0110就是6 ,那么结果就是-6
引用
int j=~i;
~ 符号表示取反
i=1111 1111 1111 1111 1111 1111 1111 1010 ,取反则为
j=0000 0000 0000 0000 0000 0000 0000 0101 就等于5了。
本文解析了一道Java笔试题,详细解释了如何通过补码运算得出int类型变量的负数表示及取反操作的结果。

142

被折叠的 条评论
为什么被折叠?



