位操作都是遵守二进制的
Java中的Integer.toBinaryString()方法能够将十进制的数字转换为二进制字符串
代码示例:
public class Test { public static void main(String[] args) { int i = 7; String b = (Integer.toBinaryString(i)); // 5的二进制的表达101 System.out.println(i+" 的二进制表达是: "+b); } }
输出:
参加运算的两个数据,按二进制位进行“与”运算。
运算规则:0&0=0; 0&1=0; 1&0=0; 1&1=1;
两位同时为“1”,结果才为“1”,否则为0
public static void main(String[] args) { int i=5; int j=6; System.out.println(Integer.toBinaryString(i)); //5的二进制是101 System.out.println(Integer.toBinaryString(j)); //6的二进制是110 System.out.println(i&j); }
5的二进制是101
6的二进制是110
5&6 对每一位进行与运算,得到 100->4
参加运算的两个对象,按二进制位进行“或”运算。
运算规则:0|0=0; 0|1=1; 1|0=1; 1|1=1;
参加运算的两个对象只要有一个为1,其值为1。
public static void main(String[] args) { int i=5; int j=6; System.out.println(Integer.toBinaryString(i)); //5的二进制是101 System.out.println(Integer.toBinaryString(j)); //6的二进制是110 System.out.println(i|j); }
5的二进制是101
6的二进制是110
所以 5|6 对每一位进行或运算,得到 111->7
参加运算的两个数据,按二进制位进行“异或”运算。
运算规则:0^0=0; 0^1=1; 1^0=1; 1^1=0;
参加运算的两个对象,如果两个相应位为“异”(值不同),则该位结果为1,否则为0。
public class Test { public static void main(String[] args) { int i=5; int j=6; System.out.println(Integer.toBinaryString(i)); //5的二进制是 101 System.out.println(Integer.toBinaryString(j)); //6的二进制是110 System.out.println(i^j); System.out.println(i^0); System.out.println(i^i); } }
取非(~)
5 的二进制是 00000101
所以取反即为 11111010,换算成十进制即为-6
左移右移左移:根据一个整数的二进制表达,将其每一位都向左移动,最右边一位补0
public class HelloWorld { public static void main(String[] args) { int i =4; System.out.println(Integer.toBinaryString(i));//100 System.out.println(i<<1);//左移1位后,变成1000 System.out.println(i>>1); } }
i<<n的规律:i*2的n次方
i>>n的规律:i/2的n次方