首页 > 代码库 > Java的位运算

Java的位运算

左移位操作

左移位运算的符号为【<<】,左移位运算符左面的操作元称作被移位数,右面的操作数称作移位量。

左移位运算是双目运算符,操作元必须是整型类型的数据,其移动过程是:【a << n】运算的过程是通过将a的所有位都左移n位,每左移一个位,左边的最高位上的0或1被移出丢弃,并用0填充右边的低位

注意:

  1. 如果a是byte、short或int型数据,总是先计算出n%32的结果m,然后进行a<<m运算
  2. 对于long型数据,总是先计算出n%64的结果m,然后进行a << m运算

右移位操作

右移位运算的符号为【>>】,右移位运算符左面的操作元称作被移位数,右面的操作数称作移位量。

右移位运算时双目运算符,操作元必须是整型类型的数据,其移动过程是:【a >> n】运算的过程是通过将a的所有位都右移n位,每右移一个位,右边的最低位上的0或1被移出丢弃,并用0或1填充左边的高位【a是正数时用0填充,负数时用1填充】

注意:

  1. 如果a是byte、short或int型数据,总是先计算出n%32的结果m,然后进行a<<m运算
  2.  对于long型数据,总是先计算出n%64的结果m,然后进行a << m运算
/**************************************华丽的分割线性**************************************************/
      以下为常用的比特位操作
/****************************************************************************************************/
public class BitUtil {        public static int alterBitValue(int source,int pos,boolean zero) {        if(zero) { /**source的第pos比特位置为0*/            return source & Integer.MAX_VALUE ^ (1 << pos -1);        }        /**source的第pos比特位置为1*/        return source | (1 << pos -1);    }        public static int getBitValue(int source,int pos) {        /**保留source第pos位的比特值,其余为置为0*/        source = source & (Integer.MAX_VALUE & (1 << pos -1));        source = source >> pos -1;        if(source == 1)             return 1;        return 0;    }        public static void main(String []args) {        /**结果应为4*/        System.out.println(BitUtil.alterBitValue(6, 2, true));        /**结果应为19*/        System.out.println(BitUtil.alterBitValue(3, 5, false));        /**结果应为0*/        System.out.println(BitUtil.getBitValue(5, 2));        /**结果应为1*/        System.out.println(BitUtil.getBitValue(5, 3));    }    }

 

Java的位运算