这段时间看bitwise operator,看到一个题目转过来

   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了。

你可能感兴趣的:(F#,J#)