//请教一个笔试题,:
public static void main(String[] args) {
// TODO Auto-generated method stub
int i= 0xFFFFFFFA;
int j=~i;
System.out.println(i);
System.out.println(j);
}
/*结果为什么是:
-6
5
为什么*/
[quote]
int i= 0xFFFFFFFA;
[/quote]
最高位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
[quote]
int j=~i;
[/quote]
~ 符号表示取反
i=1111 1111 1111 1111 1111 1111 1111 1010 ,取反则为
j=0000 0000 0000 0000 0000 0000 0000 0101 就等于5了。