位运算符

原码:就是二进制定点表示法,即最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小。

反码:正数的反码与其原码相同;负数的反码是对其原码逐位取反,但符号位除外。

补码:正数的补码与其原码相同;负数的补码是在其反码的末位加1。

计算机表示出来的是原码,在内存中参与计算的是补码。

                                                                                                                   位运算符

运算符

运算

范例

<<

左移

3 << 2 = 12 --> 3*2*2=12

>>

右移

3 >> 1 = 1  --> 3/2=1

>>>

无符号右移

3 >>> 1 = 1 --> 3/2=1

&

与运算

6 & 3 = 2

|

或运算

6 | 3 = 7

^

异或运算

6 ^ 3 = 5

~

反码

~6 = -7


1.   按位与运算&

任何二进制位和0进行&运算,结果是0;和1进行&运算结果是原值。(有0则0)

int a=10;
int b=20;
System.out.println(a&b);
 * a=10 的二进制是:00000000 00000000 00000000 00001010
 * b=20 的二进制是:00000000 00000000 00000000 00010100
 * 00000000 00000000 00000000 00001010
 * &
 * 00000000 00000000 00000000 00010100
* -------------------------------------------
*  00000000 00000000 00000000 00000000
*  结果是:0


2.   按位或运算|

任何二进制位和0进行 | 运算,结果是原值;和1进行 | 运算结果是1。(有1则1)
int a=10;
int b=20;
System.out.println(a|b);
	 * a=10 的二进制是:00000000 00000000 00000000 00001010
	 * 
	 * b=20 的二进制是:00000000 00000000 00000000 00010100
	 * 
	 * 00000000 00000000 00000000 00001010
	 * |
	 * 00000000 00000000 00000000 00010100
	 * -------------------------------------------
	 * 00000000 00000000 00000000 00011110
	 * 结果是: 30

3.按位异或运算 ^

任何相同二进制位进行 ^ 运算,结果是0;不相同二进制位 ^ 运算结果是1。(相同则0,不同则1)
	int a=10;
	int b=20;
	System.out.println(a^b);
	 * a=10 的二进制是:00000000 00000000 00000000 00001010
	 * 
	 * b=20 的二进制是:00000000 00000000 00000000 00010100
	 * 
	 * 00000000 00000000 00000000 00001010
	 * ^
	 * 00000000 00000000 00000000 00010100
	 * -------------------------------------------
	 * 00000000 00000000 00000000 00011110
	 * 结果是: 30


4.   求反运算~

二进制位进行 ~ 运算 ,1变0,0变1
int a=10;
System.out.println(~a);
	 * 00000000 00000000 00000000 00001010
	 * ~
	 * -------------------------------------------
	 * 11111111 11111111 11111111 11110101 补码
	 * 11111111 11111111 11111111 11110100 反码
	 * 10000000 00000000 00000000 00001011 原码
	 * 结果是:10


5.   左移运算<<

空位补0,被移除的高位丢弃。

int a=3<<4;
System.out.println(a);
/*把3的二进制位向左移动4位
*          00000000 00000000 00000000 00000011
*  (0000)0000 00000000 00000000 00000011(0000)
* 二进制结果:00110000  转换成十进制结果: 48
int e=-5<<4;
System.out.println(e);
/*把-5向左移动4位
 *     10000000 00000000 00000000 00000101 原码
 *     11111111 11111111 11111111 11111010 反码
 *     11111111 11111111 11111111 11111011 补码
 * 11111111 11111111 11111111 11111011(0000)
 * 1111 11111111 11111111 111110110000  补码
 * 1111 11111111 11111111 111110101111  反码
 * 1000 00000000 00000000 000001010000 原码
 * 十进制结果-80
 */


6.   右移运算>>

被移位的二进制最高位是0,右移后,空缺位补0;最高位是1,最高位补1。
int b=5>>4;
/*把5的二进制位向右移动4位
 * 00000000 00000000 00000000 00000101
 * (0000)00000000 00000000 00000000 0000(0101)
结果是:0

int d=-5>>4;
System.out.println(d);
/*把-5向右移动4位
* 10000000 00000000 00000000 00000101 原码
* 11111111 11111111 11111111 11111010 反码
* 11111111 11111111 11111111 11111011 补码
* 111111111111 11111111 11111111 1111(1011)
* 111111111111 11111111 11111111 1111  补码
* 111111111111 11111111 11111111 1110  反码
* 100000000000 00000000 00000000 0001 原码
* 十进制结果-1
 */

7.   无符号右移>>>

被移位二进制最高位无论是0或者是1,空缺位都用0补。
int b=5>>>4;
/*把5的二进制位向右移动4位
* 00000000 00000000 00000000 00000101
* (0000)00000000 00000000 00000000 0000(0101)
结果是:0
计算出24的二进制:11000   :-24 >>> 2
原码:10000000 00000000 00000000 00011000
反码:11111111 11111111 11111111 11100111
补码:11111111 11111111 11111111 11101000
		
11111111 11111111 11111111 11101000
0011111111 11111111 11111111 111010(00)



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值