A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 齐连涛 中级黑马   /  2012-10-31 14:10  /  923 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

class OppositeDemo
{
        public static void main(String[] args)
        {
                System.out.println(6^0xffffffff);                       
                System.out.println(6^0xffffffff+1);
                System.out.println((6^0xffffffff)+1);
                System.out.println((6^0xffffffff)>>1);//-4
                System.out.println(6^0xffffffff>>1);//-7         
                System.out.println(((6<<1^0xffffffff)>>1)+1);       
                System.out.println((6<<1^0xffffffff)>>1+0b00000000000000000000000000000001);       
               
        }
}


验证:
1.“+”优先级大于<<或>>,它们又都大于^。
2.获取一个正数相反数的补码,在这个正数取反之前右移,位数不会影响到原来的有效位,再取反,然后再右移相应的位数,然后加1,也不影响结果。
3.负数右移在最高位补的是1.//-7结果可知
4.“+1”和“+0b00000000000000000000000000000001”效果一样。

评分

参与人数 1技术分 +1 收起 理由
韩军博 + 1 神马都是浮云

查看全部评分

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马