位运算符的介绍,以负数的位运算为例----------java基础

>>和<<运算符将二进制位进行右移或者左移操作

>>>运算符也是将二进制位进行右移,而在右移时用0填充高位。不存在<<<运算符

而>>运算符则是用符号位填充高位

/**
 * 求负数的位运算
 */
//1.   -10 >> 2  = ?
//2.   -10的原码: 1000 0000 0000 0000 0000 0000 0000 1010   最高位代表符号位
//3.   -10的反码: 1111 1111 1111 1111 1111 1111 1111 0101   符号为不变,其他位相反
//4.   -10的补码:1111 1111 1111 1111 1111 1111 1111 0110   补码为反码加1
//5. 补码右移2为:1111 1111 1111 1111 1111 1111 1111 1101
//6.  补码取反为: 1000 0000 0000 0000 0000 0000 0000 0010
//7再加一得原码:  1000 0000 0000 0000 0000 0000 0000 0011    -3
public class text01 {
    public static void main(String[] args) {
        System.out.println(-10>>2);
    }
}

下面以负数的位运算为例:

/**
 * 求负数的位运算
 */
1.   -10 >> 2  = ?
2.   -10的原码: 1000 0000 0000 0000 0000 0000 0000 1010   最高位代表符号位
3.   -10的反码: 1111 1111 1111 1111 1111 1111 1111 0101   符号为不变,其他位相反
4.   -10的补码:1111 1111 1111 1111 1111 1111 1111 0110   补码为反码加1
5. 补码右移2为:1111 1111 1111 1111 1111 1111 1111 1101
6.  补码取反为: 1000 0000 0000 0000 0000 0000 0000 0010
7再加一得原码:  1000 0000 0000 0000 0000 0000 0000 0011    -3

简单来说:

负数的位运算,需要在补码的基础上进行位运算,然后再转化为原码。

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值