黑马程序员技术交流社区
标题:
验证点问题
[打印本页]
作者:
齐连涛
时间:
2012-10-31 14:10
标题:
验证点问题
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”效果一样。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2