java 位运算

Java 中的位运算:

>>> 无符号右移和 >> 右移的区别

  • 无符号右移动右边用0补齐。>>右移动,如果说符号位是1,则右边用1填充,如果是0则用0填充。0代表的是 正数,1代表的是负数。
  • 二进制负数 的计算方法 ,二进制的补位加1就是她的值;

在计算机中负数采用二进制的补码表示,10进制转为二进制得到的是源码,将源码按位取反得到的是反码,反码加1得到补码;例如(1的二进制为 0000 0001 ;他的反码是1111 1110 ;加1得到 1111 1111 这就是-1)

二进制的最高位是符号位,0表示正,1表示负。

1: ^(亦或运算),针对二进制,相同的为0,不同的为1;
代码如下:
  public static void main(String[] args) {
        System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
        System.out.println("3的二进制表达:"+Integer.toBinaryString(3));

        System.out.println("2^3运算的结果是 :"+(2^3));
        //控制台的输出:
     /*   2的二进制表达:10
        3的二进制表达:11
        2^3运算的结果是 :1*/
    }
2:&(与运算) 针对二进制,只要有一个为0,就为0
代码如下:
     System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
        System.out.println("3的二进制表达:"+Integer.toBinaryString(3));

        System.out.println("2&3运算的结果是 :"+(2&3));
        //控制台的输出:
     /*   2的二进制表达:10
          3的二进制表达:11
          2&3运算的结果是 :2*/
3:<<(向左位移) 针对二进制,转换成二进制后向左移动N位,后面用0补齐
代码如下:
 System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
        System.out.println("3的二进制表达:"+Integer.toBinaryString(3));

        System.out.println("2<<3运算的结果是 :"+(2<<4));
         System.out.println("-96的二进制表达:"+Integer.toBinaryString(-96));

        System.out.println("-96<<1运算的结果是 :"+(-96<<1));
        //控制台的输出:
     /*   2的二进制表达:10
          3的二进制表达:11
          2<<3运算的结果是 :32
          -96的二进制表达:11111111111111111111111110100000
		  -96<<1运算的结果是 :-192
          */
4:>>(向右位移) 针对二进制,转换成二进制后向右移动n位(最高位需要保持不变,考虑最高位符号0代表正数,1代表负数)
代码如下:
public static void main(String[] args) {
        System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
        System.out.println("3的二进制表达:"+Integer.toBinaryString(3));

        System.out.println("2>>3运算的结果是 :"+(2>>1));
        //控制台的输出:
     /*   2的二进制表达:10
          3的二进制表达:11
          2>>3运算的结果是 :1*/
    }
5:>>>(无符号右移) 无符号右移,忽略符号位,空位都以0补齐

10进制转二进制的时候,因为二进制数一般分8位、 16位、32位以及64位 表示一个十进制数,所以在转换过程中,最高位会补零。
在计算机中负数采用二进制的补码表示,10进制转为二进制得到的是源码,将源码按位取反得到的是反码,反码加1得到补码
二进制的最高位是符号位,0表示正,1表示负

>>>与>>唯一的不同是它无论原来的最左边是什么数,统统都用0填充。
——比如,byte是8位的,-1表示为byte型是11111111(补码表示法)
b>>>4就是无符号右移4位,即00001111,这样结果就是15。

可见正数做>>>运算的时候和>>是一样的。区别在于负数运算
无符号右移规则和右移运算是一样的,只是填充时不管左边的数字是正是负都用0来填充,无符号右移运算只针对负数计算,因为对于正数来说这种运算没有意义
无符号右移运算符>>> 只是对32位和64位的值有意义

代码如下:

    public static void main(String[] args) {
        System.out.println("16的二进制表达:"+Integer.toBinaryString(16));
        System.out.println("-16的二进制表达:"+Integer.toBinaryString(-16));

        System.out.println("16>>2运算的结果是 :"+((16)>>2));
        System.out.println("-16>>2运算的结果是 :"+((-16)>>2));
        System.out.println("16>>>2运算的结果是 :"+((16)>>>2));
        System.out.println("-16>>>2运算的结果是 :"+((-16)>>>2));
        //控制台的输出:
//        16的二进制表达:10000
//         -16的二进制表达:11111111111111111111111111110000
//        16>>2运算的结果是 :4
//        -16>>2运算的结果是 :-4
//        16>>>2运算的结果是 :4
//        -16>>>2运算的结果是 :1073741820

    }
    
```




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值