Java移位运算符

简述

Java有三种移位运算符,分别为:

  1. 左移运算符 <<
  2. 右移运算符 >>
  3. 无符号右移运算符 >>>

首先,移位运算符根据名字可知是使用二进制进行运算的。在Integer.java中,我们可以看到有两个静态常量,MIN_VALUEMAX_VALUE,这两个常量控制了Integer的最小值和最大值,如下:

    /**
     * A constant holding the minimum value an {@code int} can
     * have, -2<sup>31</sup>.
     */
    @Native public static final int   MIN_VALUE = 0x80000000;

    /**
     * A constant holding the maximum value an {@code int} can
     * have, 2<sup>31</sup>-1.
     */
    @Native public static final int   MAX_VALUE = 0x7fffffff;

注释上说明这两个值得范围:

MIN_VALUE(最小值) = -2^31 = -2,147,483,648‬
MAX_VALUE(最大值) = 2^31 = 2,147,483,647

在32位运算中,首位为1则代表负数,0则代表正数,如:

1000 0000 0000 0000 0000 0000 0000 0000 负数,该值等于MIN_VALUE
0111 1111 1111 1111 1111 1111 1111 1111 正数,该值等于MAX_VALUE

根据上述可知,Integer是32位运算的。


左移运算符 <<

使用 << 时,需要在低位进行补0,例子如下:

        int a = 3;
        System.out.println(Integer.toBinaryString(a));

        int b = a << 1;
        System.out.println(Integer.toBinaryString(b));
        System.out.println(b);

        System.out.println("----------------------------------------------");

        int c = -3;
        System.out.println(Integer.toBinaryString(c));

        int d = c << 1;
        System.out.println(Integer.toBinaryString(d));
        System.out.println(d);

输入如下:

11
110
6
----------------------------------------------
11111111111111111111111111111101
11111111111111111111111111111010
-6

可以清楚的看到 3 << 1 时,在后面补0,得到 110 即等于6;


右移运算符 >>

右移运算符时,正数高位补0,负数高位补1。如:

        int a = 3;
        System.out.println(Integer.toBinaryString(a));

        int b1 = a >> 1;
        System.out.println(Integer.toBinaryString(b1));
        System.out.println(b1);

        System.out.println("----------------------------------------------");

        int c = -3;
        System.out.println(Integer.toBinaryString(c));

        int d = c >> 1;
        System.out.println(Integer.toBinaryString(d));
        System.out.println(d);

输出如下:

11
1
1
----------------------------------------------
11111111111111111111111111111101
11111111111111111111111111111110
-2

无符号右移 >>>

在正数当中,>> 和 >>> 是一样的。负数使用无符号右移时,则高位不进行补位。

        int c = -3;
        System.out.println(Integer.toBinaryString(c));

        int d = c >>> 1;
        System.out.println(Integer.toBinaryString(d));
        System.out.println(d);

输出如下:

11111111111111111111111111111101
1111111111111111111111111111110
2147483646

总结

左移运算符 << : 需要在低位进行补0
右移运算符 >> : 正数高位补0,负数高位补1
无符号右移运算符 >>> :在正数当中,>> 和 >>> 是一样的。负数使用无符号右移时,则高位不进行补位

个人博客网址: https://colablog.cn/

如果我的文章帮助到您,可以关注我的微信公众号,第一时间分享文章给您
微信公众号

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值