Java的位运算(bitwise operators)

Java的位运算(bitwise operators)直接对整数类型的位进行操作,这些整数类型包括long、int、short、char和 byte,位运算符具体如下表:

运算符 说明
<< 左移位,在低位处补0
>> 右移位,若为正数则高位补0,若为负数则高位补1
>>> 无符号右移位,无论正负都在高位补0
& 与(AND),对两个整型操作数中对应位执行布尔代数,两个位都为1时输出1,否则0。
| 或(OR),对两个整型操作数中对应位执行布尔代数,两个位都为0时输出0,否则1。
~ 非(NOT),一元运算符。
^ 异或(XOR),对两个整型操作数中对应位执行布尔代数,两个位相等0,不等1。
<<= 左移位赋值。
>>= 右移位赋值。
>>>= 无符号右移位赋值。
&= 按位与赋值。
|= 按位或赋值。
^= 按位异或赋值。

左移位(<<)
程序:

public class LeftMoving{
    public static void main(String[] args){
           System.out.println("5<<3="+(5<<3));
    }
}

输出结果:
5<<3=40
计算过程:
0000 0000 0000 0000 0000 0000 0000 0101 ? 5
0000 0000 0000 0000 0000 0000 0010 1000 ? 40

右移位(>>)
正数
程序:

public class PlusRightMoving{
    public static void main(String[] args){
           System.out.println("5>>1="+(5>>1));
    }
}

输出结果:
5>>1=2
计算过程:
0000 0000 0000 0000 0000 0000 0000 0101 ? 5
0000 0000 0000 0000 0000 0000 0000 0010 ? 2

负数
程序:

public class NegativeRightMoving{
    public static void main(String[] args){
           System.out.println("-5>>1="+(-5>>1));
    }
}

输出结果:
-5>>1=-3
计算过程:
1111 1111 1111 1111 1111 1111 1111 1011 ? -5
1111 1111 1111 1111 1111 1111 1111 1101 ? -3

无符号右移位(>>>)
程序:

public class UnsignedRightMoving{
    public static void main(String[] args){
        System.out.println("-5>>>1="+(-5>>>1));
    }
}

输出结果:
-5>>>1=2147483645
计算过程:
1111 1111 1111 1111 1111 1111 1111 1011 ? -5
0111 1111 1111 1111 1111 1111 1111 1101 ? 2147483645

补充个Java中的基本数据类型的相关知识。

数据类型 大小 最小值 最大值
boolean
byte 8-bit -128 +127
char 16-bit Unicode 0 Unicode 216-1
short 16-bit -215 +215-1
int 32-bit -231 +231-1
float 32-bit IEEE754 IEEE754
long 64-bit -263 263-1
double 64-bit IEEE754 IEEE754
void

这里包括了float和double两个浮点型,在本文中对其不予考虑,因为位运算是针对整型的。进行位操作时,除long型外,其他类型会自动转成int型,转换之后,可接受右操作数长度为32。进行位运算时,总是先将短整型和字节型值转换成整型值再进行移位操作的。
程序:

public class ByteLeftMoving{
public static void main(String[] args){
        byte b = 127;
        System.out.println("b<<3="+(b<<3));
        System.out.println("(byte)(b<<3)="+(byte)(b<<3));
    }
}  

输出结果:
b<<3=1016
(byte)(b<<3)=-8

程序:

public class CharLeftMoving{  

public static void main(String[] args){
        char c = 'l';
        System.out.println("c<<3="+(c<<3));
        System.out.println("(char)(c<<3)="+(char)(c<<3));
    }
}  

输出结果:
c<<3=864
(char)(c<<3)=?

以上两个例子全部编译通过,由此可以看出,当byte和char进行移位运算时不会发生错误,并且均按照整型进行计算,当计算结果超出byte或是char所能表示的范围时则进行相应的转换(分别输出了结果-8和?)。

位运算中的操作数
在进行移位运算时要注意整型和长整型在内存中的位数(整型是32位,长整型是64位),如果移位操作数超出了该位数则取模计算,例如:int型数据是32位的,如果左移35位是什么结果?
程序:

public class LeftMoving{
    public static void main(String[] args){
           System.out.println("5<<35="+(5<<35));
    }
}

输出结果:
5<<35=40
该结果与5<<3完全相同。
无论正数、负数,它们的右移、左移、无符号右移 32位都是其本身,比如 -5<<32=-5、-5>>32=-5、-5>>>32=-5。
一个有趣的现象是,把 1 左移 31 位再右移 31位,其结果为 -1。
计算过程如下:
0000 0000 0000 0000 0000 0000 0000 0001
1000 0000 0000 0000 0000 0000 0000 0000
1111 1111 1111 1111 1111 1111 1111 1111
位运算要求操作数为整数,操作数不能是字符串也不能是小数。
如下列程序:

public class BitMath{  

    public static void main(String[] args){
        String s = "Hello";
        long l = 99;
        double d = 1.11;
        int i = 1;
        int j = 0;
        System.out.println("j<<s="+j<<s);    //编译错误语句
        System.out.println("j<<d="+j<<d);    //编译错误语句
        System.out.println("i<<j="+i<<j);    //编译可以通过
        System.out.println("i<<l="+i<<l);    //编译可以通过
    }
}  

由于位运算是二进制运算,不要与一些八进制数搞混,java中二进制数没有具体的表示方法。

public class BitMath{
    public static void main(String[] args){
        System.out.println("010|4="+(010|4));
    }
}

输出结果:
010|4=12
计算过程:
0000 0000 0000 0000 0000 0000 0000 1000 ?8
0000 0000 0000 0000 0000 0000 0000 0100 ?4
进行“或”计算结果为:
0000 0000 0000 0000 0000 0000 0000 1100 ?12
当位运算中遇见负数,必须把它转成补码(不知道什么是补码的补习功课去)再进行计算,而不是使用原码。
程序:

public class BitMath{
    public static void main(String[] args){
        try {
            int x = -7;
            System.out.println("x>>1="+(x>>1));
        } catch(Exception e) {
            System.out.println("Exception");
        }
    }
}

输出结果:
x>>1=-4
计算过程:
1111 1111 1111 1111 1111 1111 1111 1001 ?-7
1111 1111 1111 1111 1111 1111 1111 1100 ?-4

public class BitMath{  

    public static void main(String[] args){
        int i = 1;
        int j = -1;
        System.out.println("1>>>31="+(i>>>31));
        System.out.println("-1>>31="+(j>>31));
    }
}  

输出结果:
1>>>31=0
-1>>31=-1
程序:

public class BitMath{  

    public static void main(String[] args){
        int a = 1;
        a <<= 31;
        a >>= 31;
        a >>= 1;
        System.out.println("a="+a);
        int b = 1;
        b <<= 31;
        b >>= 31;
        System.out.println("b="+b);
        int c = 1;
        c >>= 31;
        c <<= 31;
        System.out.println("c="+c);
    }
}  

输出结果:
a=-1
b=-1
c=0
计算过程:
0000 0000 0000 0000 0000 0000 0000 0001 ?a=1
1000 0000 0000 0000 0000 0000 0000 0000 ?a=a<<31后,这里被当作是负数
1111 1111 1111 1111 1111 1111 1111 1111 ?a=a>>31后,结果为-1
1111 1111 1111 1111 1111 1111 1111 1111 ?a=a>>1后,结果仍为-1
0000 0000 0000 0000 0000 0000 0000 0001 ?c=1
0000 0000 0000 0000 0000 0000 0000 0000 ?c=c>>31后为0
0000 0000 0000 0000 0000 0000 0000 0000 ?0左移31位仍为0

时间: 2024-09-17 04:19:59

Java的位运算(bitwise operators)的相关文章

Java中位运算(移位、位与、或、异或、非) 的简单实例_java

复制代码 代码如下: public class Test {     public static void main(String[] args) {         // 1.左移( << )         // 0000 0000 0000 0000 0000 0000 0000 0101 然后左移2位后,低位补0://         // 0000 0000 0000 0000 0000 0000 0001 0100 换算成10进制为20         System.out.pri

java的位运算相关问题

问题描述 有这么一个表达式:x是8位的byte类型数据(x >> 4) & 0xF,这个是不是说,把x的低4位舍掉(右移),然后把高4位变成低4位,取这个低4位的值?(更直接的就是取x的高4位)如果是这样的话,Character.forDigit((x >> 4) & 0xF , 16)又是什么意思呢? 解决方案 将x >> 4) & 0xF按照16进制转换为十进制

[LeetCode]--190. Reverse Bits(不是很懂的位运算)

补充知识,Java的位运算(bitwise operators) Reverse bits of a given 32 bits unsigned integer. For example, given input 43261596 (represented in binary as 00000010100101000001111010011100), return 964176192 (represented in binary as 00111001011110000010100101000

[大数据量]java移位运算与位运算与数据类型的存储

站在巨人的肩膀上,参考其他博客文章,汇总于此:  1G=1024M=1024K=1024BYTE=8BIT  Java数据类型的存储:(举例说明) 问:int 型的在内存中怎么存储,假设 int a=21:那么a是怎么被存到计算机里的.怎样把 a 变成二进制数. 怎么样把 a 存到 byte[]数组中? 答:int占4个字节,byte是1个字节,每个字节8位. 所以2进制的话,int最多可以表示正负一共2的32次方个数,byte则是2的8次方. e.g. int=21;在计算机中表示为00000

Java千百问_03基本语法(005)_二进制是怎样做位运算的

二进制是怎样做位运算的 程序中的所有数在计算机内存中都是以二进制的形式储存的.位运算说白了,就是直接对整数在内存中的二进制位进行操作.其他运算符看这里:java种的运算符都有哪些 大部分运算流程都是先将整数转换为二进制,然后进行相应二进制操作.常见的操作有如下几种: 下面我们详细说明,运算符的优先级看这里:java运算符的优先级是怎样的 1.按位与 and 两个二进制数进行按位与操作:相同位的两个数字都为1,则为1:若有一个不为1,则为0. 例如:00101 & 11100 = 00100 通常

java位运算&amp;amp;gt;&amp;amp;gt;&amp;amp;gt;负位运算

问题描述 java位运算>>>负位运算 请教大神 -100 >>> -1 -100 >>> 1 如何计算的 解决方案 [负数最高位为1,正数为0] [-10转换为二进制数: 10转为2进制数--> 1010 --求反--> 0101 --加1--> 0110 --补位--> 1***1 0110 -10转换为二进制数:11111111111111111111111111111111111111111111111111111111

java 简单的位运算

问题描述 java 简单的位运算 int i=0xaabbccdd : byte b1=0xdd: byte b2=0xcc: byte b3=0xbb: byte b4=0xaa: 使用位运算将i变为0xddccbbaa 解决方案 Java位运算Java位运算JAVA中的位运算 解决方案二: b1是不是0xdd? b1*16^6+b2*16^4+b3*16^2+b4

java位运算加密示例_java

创建一个类,通过位运算中的"^"异或运算符把字符串与一个指定的值进行异或运算,从而改变字符串每个字符的值,这样就可以得到一个加密后的字符串.当把加密后的字符串作为程序输入内容,再与那个指定的值进行异或运算,实现把加密后的字符串还原为原有字符串的值. 复制代码 代码如下: import java.util.Scanner;public class Example {    public static void main(String[] args) {        Scanner sc

Java位运算总结

  这是自己4年前的Java学习笔记,现发布在ITEye留作纪念,同时也希望对那些刚刚接触Java的童鞋们有些许帮助.              情如痕,缘似印,奈何情深缘浅海誓山盟空对月,流尽痴泪只为你我心再近,踏破情路惟愿红尘有你.