位运算

位运算

口诀

位运算应用口位运算应用口诀位运算应用口诀

清零取反要用与,某位置一可用或

若要取反和交换,轻轻松松用异或

运算规则

1. 按位与&

如果两个相应的二进位都为1,则该位的结果为1,否则为0;

2. 按位或|

两个对应的二进制只要有1,该位结果值为1

3. 异或运算^

相同为0,不同为1

4. 异或的两个原理:

两个相同的数异或运算的结果为:0

某数与0异或运算,结果为自身.

移位运算

要点 1:它们都是双目运算符,两个运算分量都是整形,结果也是整形

2 " >>"右移:右边的位被挤掉。对于左边移出的空位,如果是正数则空位补0,若为负数,可能补0或补1,这取决于所用的计算机系统

num<<2 相当于 num*4,num>>2 相当于num/4

4 ">>>"运算符,右边的位被挤掉,对于左边移出的空位一概补上0
位运算符的应用

无符号位移当需要移位的是正数时,与有符号位移一致

按位与&

清零特定位 (mask中特定位置0,其它位为1,s=s&mask)

例子:

//例如把a 的高八位清 0 , 保留低八位
a&255//255为(0000000011111111)

//Java中HashTable中的应用,0x7FFFFFFF为int最大值,首位为0其他都是1,用以保证hash & 0x7FFFFFFF必定为整数
int index = (hash & 0x7FFFFFFF) % tab.length;

取某数中指定位 (mask中特定位置1,其它位为0,s=s&mask)

例子:

//位掩码应用,利用位掩码可以用来管理权限
public class NewPermission {
	// 是否允许查询,二进制第1位,0表示否,1表示是
	public static final int ALLOW_SELECT = 1 << 0; // 0001
	
	// 是否允许新增,二进制第2位,0表示否,1表示是
	public static final int ALLOW_INSERT = 1 << 1; // 0010
	
	// 是否允许修改,二进制第3位,0表示否,1表示是
	public static final int ALLOW_UPDATE = 1 << 2; // 0100
	
	// 是否允许删除,二进制第4位,0表示否,1表示是
	public static final int ALLOW_DELETE = 1 << 3; // 1000
	
	// 存储目前的权限状态
	private int flag;

	/**
	 *  重新设置权限
	 */
	public void setPermission(int permission) {
		flag = permission;
	}

	/**
	 *  添加一项或多项权限
	 *  flag = 0001 | 0100,也就是0101,便拥有了Select和Update两项权限
	 */
	public void enable(int permission) {
		flag |= permission;
	}
	
	/**
	 *  删除一项或多项权限
	 *  0101&(~0001),0101&1110=0100
	 */
	public void disable(int permission) {
		flag &= ~permission;
	}
	
	/**
	 *  是否拥某些权限
	 *  0101&0001=0001,0001==ALLOW_SELECT,可知拥有查询权限
	 */
	public boolean isAllow(int permission) {
		return (flag & permission) == permission;
	}
	
	/**
	 *  是否禁用了某些权限
	 *  0101&0010=0000,可知拥有没有该权限
	 */
	public boolean isNotAllow(int permission) {
		return (flag & permission) == 0;
	}
	
	/**
	 *  是否仅仅拥有某些权限
	 */
	public boolean isOnlyAllow(int permission) {
		return flag == permission;
	}
}

按位或¦

常用来将源操作数某些位置变成1,其它位不变。 (mask中特定位置1,其它位为0 s=s ¦mask)

位异或^

使特定位的值取反(mask中特定位置1,其它位为0 s=s^mask)

不引入第三变量,交换两个变量的值

x ^= y; 
y ^= x; 
x ^= y; 

位非( ~ )

5转换为二进制:0000 0000 0000 0000 0000 0000 0000 0101


-6转换为二进制:1111 1111 1111 1111 1111 1111 1111 1010

位非:操作数的第n位为1,那么结果的第n位为0,反之

posted @ 2017-06-20 17:00  chensongxian  阅读(282)  评论(0编辑  收藏  举报