----------- 位运算符都是使用二进制计算的
1. & :如果对应位都是1,则为1,反之为0;
2. | :如果对应位都是0,则为0,反之为1;
3. ^ : 如果对应位数相同,则为0,反之为1;
4. ~ : 按位取反;
5. << : 按位左移运算符。左操作数按位左移右操作数指定的位数。
6. >> : 按位右移运算符。左操作数按位右移右操作数指定的位数。
7. >>> : 按位右移补零操作符。左操作数的值按右操作数指定的位数右移,移动得到的空位以零填充。
int sum;
int a = -10; // 1000 1010; 反 1111 0101; 补 1111 1010
int b = -7; // 1000 0111; 反 1111 1000; 补 1111 1001
int c = 10; // 0000 1010;
int d = 7; // 0000 0111;
//int 应该是 32位 然后最大位数是符号位,所以占据31位,所以int最大是2^31-1的大小,我这里就直接用8位演示;
//每次位运算是会带着符号一起进行位运算的
sum = a | b; // 补 1111 1111 | 反 1111 1110 | 原 1000 0001 -1
sum = a & b; // 补 1111 0000 | 反 1110 1111 | 原 1001 0000 | -16
sum = a & c; // 补 0000 0010 | 2
sum = ~a; // 0000 1001 | 9
sum = ~c; // 补 1111 0101 | 反 1111 0100 | 原 1000 1011 | -11
//无符号位移,会自动补齐
sum = a>>2;// 补 1111 1101 | 反 1111 1100 | 原 1000 0011 | -3
//会把1移动到符号位变成 负数
sum = Integer.MAX_VALUE<<2;// | -4
//带符号位移,会把符号位一起移动 这么大的原因是因为int是32位的
sum = a>>>3;// 536870910
sum = c>>>3;// | 1
|