这段时间看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了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值