首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

位操作语法问题Java

位操作是一种操作数据的方式,它可以使用位(bit)作为操作单位,通过移位、与、或、异或等操作来实现数据的处理。位操作在Java中可以使用位操作符来实现,例如:

  1. 按位与(&):将两个数的每一位进行与操作,如果两个数的对应位都是1,则结果为1,否则为0。
  2. 按位或(|):将两个数的每一位进行或操作,如果两个数的对应位都是0,则结果为0,否则为1。
  3. 按位异或(^):将两个数的每一位进行异或操作,如果两个数的对应位相同,则结果为0,否则为1。
  4. 按位取反(~):将一个数的每一位进行取反操作,将0变为1,将1变为0。
  5. 左移(<<):将一个数的每一位向左移动指定的位数,右侧用0填充。
  6. 右移(>>):将一个数的每一位向右移动指定的位数,左侧用符号位填充。

Java中的位操作符可以用于整数类型(byte、short、int、long)和布尔类型。位操作在Java中有很多应用场景,例如:

  1. 位掩码:可以使用位操作符来实现位掩码,即将一个数的某些位设置为1,其他位设置为0,然后与另一个数进行位与操作,从而提取或修改数据。
  2. 快速计算奇偶性:可以使用位操作符来快速计算一个数的奇偶性,即将一个数的最后一位进行与操作,如果结果为0,则为偶数,否则为奇数。
  3. 快速交换两个数:可以使用位操作符来快速交换两个数的值,即将它们的异或结果赋值给它们中的任意一个,然后再将它们的异或结果赋值给另一个数,即可完成交换。

总之,位操作是一种非常有用的数据处理方式,可以提高程序的效率和性能。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • JAVA 位操作

    【引自黑马王子的博客】Java中的位操作指定包括:
    ~ 按位非(NOT)
    & 按位与(AND)
    | 按位或(OR)
    ^ 按位异或(XOR)
    >> 右移
    >>> 无符号右移
    <<左移
    前面几个都非常简单,主要是移位操作比较容易出错.
    首先要搞清楚参与运算的数的位数,如int的是32位。long的是64位。
    如int i = 1;
    i的二进制原码表示为:
    00000000000000000000000000000001
    long l = 1;
    l的二进制原码表示为:
    0000000000000000000000000000000000000000000000000000000000000001
    二、

    正数没有反码、补码,也可以说正数的反码、补码跟原码一样。
    负数的反码为原码逐位取反,
    如int i = -1;
    10000000000000000000000000000001,最高位是符号位。正数为0,负数为1。
    逐位取反后:
    01111111111111111111111111111110即反码。
    反码加1:
    01111111111111111111111111111111即补码。
    负数都是用补码参与运算的。得到的也是补码,需要减1取反获得原码。

    三、常用的位运算符–0在位运算中是比较特殊的。

    ^ 异或。 相同为0,相异为1; 任何数与0异或都等于原值。 
    & 与。 全1为1, 有0为0;任何数与0异或都等于0。
    | 或。 有1为1, 全0为0。任何数与0或都等于原值。
    <<左移。 补0。
    >> 右移。 符号位是0补0,是1补1。
    >>>无符号右移。补0。
    ~ 非 逐位取反

    四、负数参与的运算,得到的是补码,需要将补码先减1,然后逐位取反,得到原码。即为运算结果。

    0例外,如果得到的是0,则不需减1和取反。
    另外,两个正数运算后得到的就是原码,不需减1和取反。
    举例:
    1^-1,
    -1
    10000000000000000000000000000001–原码
    01111111111111111111111111111110–反码
    01111111111111111111111111111111–补码
    1
    00000000000000000000000000000001–原码
    则1^-1等于
    01111111111111111111111111111111^
    00000000000000000000000000000001=
    01111111111111111111111111111110–补码
    01111111111111111111111111111101–反码
    10000000000000000000000000000010–原码==-2
    即1^-1=-2
    举例:
    1^-2
    -2
    10000000000000000000000000000010–原码
    01111111111111111111111111111101–反码
    01111111111111111111111111111110–补码
    1
    00000000000000000000000000000001–原码
    则1^-2等于
    01111111111111111111111111111110^
    00000000000000000000000000000001=
    01111111111111111111111111111111–补码
    01111111111111111111111111111110–反码
    10000000000000000000000000000001–原码==-1
    1.<<
    逻辑左移,右边补0,符号位和其他位一样.
    正数:
    x<<1一般相当于2x,但是可能溢出.
    溢出范围: 230~(231-1) 二进制表示 010000…000到01111….1111,移位后最高为变为1了,变成负数了.
    负数:
    x<<1一般也相当于2x,也有可能溢出.所以, x*32可以写成x<<5
    溢出范围: -231~-(230+1)

    03

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券