左移位操作
左移位运算的符号为【<<】,左移位运算符左面的操作元称作被移位数,右面的操作数称作移位量。
左移位运算是双目运算符,操作元必须是整型类型的数据,其移动过程是:【a << n】运算的过程是通过将a的所有位都左移n位,每左移一个位,左边的最高位上的0或1被移出丢弃,并用0填充右边的低位
注意:
- 如果a是byte、short或int型数据,总是先计算出n%32的结果m,然后进行a<<m运算
- 对于long型数据,总是先计算出n%64的结果m,然后进行a << m运算
右移位操作
右移位运算的符号为【>>】,右移位运算符左面的操作元称作被移位数,右面的操作数称作移位量。
右移位运算时双目运算符,操作元必须是整型类型的数据,其移动过程是:【a >> n】运算的过程是通过将a的所有位都右移n位,每右移一个位,右边的最低位上的0或1被移出丢弃,并用0或1填充左边的高位【a是正数时用0填充,负数时用1填充】
注意:
- 如果a是byte、short或int型数据,总是先计算出n%32的结果m,然后进行a<<m运算
- 对于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)); } }