左移位操作
左移位运算的符号为【<<】,左移位运算符左面的操作元称作被移位数,右面的操作数称作移位量。
左移位运算是双目运算符,操作元必须是整型类型的数据,其移动过程是:【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));
} }