位运算-位与(&)、位或(|)、位非(~)、异或(^)

大概解释,就在代码中的注释,大家可以看注释

/**
 *类说明:演示位运算
 */
public class IntToBinary {
	
    public static void main(String[] args)   {
    	
    	int data = 4;
    	System.out.println("the 4 is "+Integer.toBinaryString(data));
    	
    	//位与  &(1&1=1 1&0=0 0&0=0)
    	System.out.println("the 4 is "+Integer.toBinaryString(4));
    	System.out.println("the 6 is "+Integer.toBinaryString(6));
    	System.out.println("the 4&6 is "+Integer.toBinaryString(4&6));
    	//位或 | (1|1=1 1|0=1 0|0=0)
    	System.out.println("the 4|6 is "+Integer.toBinaryString(4|6));
    	//位非~(~1=0  ~0=1)
    	System.out.println("the ~4 is "+Integer.toBinaryString(~4));
    	//位异或 ^ (1^1=0 1^0=1 0^0=0)
    	System.out.println("the 4^6 is "+Integer.toBinaryString(4^6));
    	
    	// <<有符号左移 >>有符号的右移  >>>无符号右移
    	
    	//取模的操作 a % (2^n) 等价于 a&(2^n-1)
    	System.out.println("the 345 % 16 is "+(345%16)+ " or "+(345&(16-1)));
    	
    } 
}

输出

其实关于位运算还可以用作权限管理

/**
 *类说明:位运算应用
 */
public class Permission {
	
    // 是否允许查询,二进制第1位,0表示否,1表示是  
    public static final int ALLOW_SELECT = 1 << 0; // 0001  = 1
      
    // 是否允许新增,二进制第2位,0表示否,1表示是  
    public static final int ALLOW_INSERT = 1 << 1; // 0010  = 2
      
    // 是否允许修改,二进制第3位,0表示否,1表示是  
    public static final int ALLOW_UPDATE = 1 << 2; // 0100  =4
      
    // 是否允许删除,二进制第4位,0表示否,1表示是  
    public static final int ALLOW_DELETE = 1 << 3; // 1000  = 8
    // 存储目前的权限状态  
    private int flag; 
    //设置用户的权限
    public void setPer(int per) {
    	flag = per;
    }
    //增加用户的权限(1个或者多个)
    public void enable(int per) {
    	flag = flag|per;
    }
  //删除用户的权限(1个或者多个)
    public void disable(int per) {
    	flag = flag&~per;
    }
    //判断用户的权限
    public boolean isAllow(int per) {
    	return ((flag&per)== per);
    }
    //判断用户没有的权限
    public boolean isNotAllow(int per) {
    	return ((flag&per)==0);
    }
  
    public static void main(String[] args) {
		int flag = 15;
		Permission permission = new Permission();
		permission.setPer(flag);
		permission.disable(ALLOW_DELETE|ALLOW_INSERT);
		System.out.println("select = "+permission.isAllow(ALLOW_SELECT));
		System.out.println("update = "+permission.isAllow(ALLOW_UPDATE));
		System.out.println("insert = "+permission.isAllow(ALLOW_INSERT));
		System.out.println("delete = "+permission.isAllow(ALLOW_DELETE));
		
		
	}
}

输出

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值