使用二进制进行权限或状态控制

<h3>文章转载出处:http://blog.csdn.net/scorpio3k/article/details/8100890</h3>

基本概念

  1. package test;  
  2.   
  3. public class Rights {  
  4.   
  5.     public static void main(String[] args) {  
  6.         int a=1// 001 状态a  
  7.         int b=2// 010 状态b  
  8.         int c=4// 100 状态c  
  9.           
  10.         int ab = a | b; // 001 | 010 = 011 初始状态  
  11.           
  12.         System.out.println(ab | c); // 011 | 100 = 111 添加c的状态  
  13.         System.out.println(ab & (~b)); // 011 & (~010) = 011 & 101 = 001 去除b的状态  
  14.           
  15.         System.out.println((ab & b) == b); // 011 & 010 = 010 判断是否有b的权限:(ab & b)==b  
  16.         System.out.println((ab & c) == c); // 011 & 100 = 000   
  17.     }  
  18. }  
package test;

public class Rights {

	public static void main(String[] args) {
		int a=1; // 001 状态a
		int b=2; // 010 状态b
		int c=4; // 100 状态c
		
		int ab = a | b; // 001 | 010 = 011 初始状态
		
		System.out.println(ab | c); // 011 | 100 = 111 添加c的状态
		System.out.println(ab & (~b)); // 011 & (~010) = 011 & 101 = 001 去除b的状态
		
		System.out.println((ab & b) == b); // 011 & 010 = 010 判断是否有b的权限:(ab & b)==b
		System.out.println((ab & c) == c); // 011 & 100 = 000 
	}
}


使用二进制进行权限或状态控制

  1. package test;  
  2.   
  3. public class Test {  
  4.   
  5.     /**  
  6.      * @param args  
package test;

public class Test {

	/**
	 * @param args
  1.          * @author 李文锴  
  2.      */  
  3.     public static void main(String[] args) {  
  4.   
  5.         /** 
  6.          * 四种权限 ,当前定义为int,以下二进制表示只取后四位作说明 
  7.          */  
  8.   
  9.         // 添加  
  10.         int c = 1;// ...0001=2^0  
  11.         // 查询  
  12.         int r = 2;// ...0010=2^1  
  13.         // 修改  
  14.         int u = 4;// ...0100=2^3  
  15.         // 删除  
  16.         int d = 8;// ...1000=2^4  
  17.   
  18.         /** 
  19.          *  
  20.          * 大家可以观察四种权限的二进制表示的规律 ,都是2的N次方, 
  21.          * 就表示本身,添加权限有最后一位为其它为0,查询倒数第二位为1其它都为0,修改倒数第三个为1其它都为0,删除倒数第四个为1其它都为0 
  22.          *  
  23.          */  
  24.   
  25.         /** 
  26.          * 这样表示有哪种权限时可以用 |(按位或) 操作 
  27.          *  
  28.          */  
  29.   
  30.         // 用户A有添加和修改权限  
  31.         int usera = c | r | u;  
  32.   
  33.         // 用户B有添加和删除权限  
  34.         int userb = c | d;  
  35.   
  36.         /** 
  37.          * 判断用户是否有某种权限用用户权限和要判断的权限进行 &(按位与) 操作,结果为要判断的权限值时表示用户有此权限,否则没有此权限 
  38.          */  
  39.         System.out.println();  
  40.         if ((usera & u) == u) {  
  41.             System.out.println("用户a有更新权限");  
  42.         } else {  
  43.             System.out.println("用户a没有有更新权限");  
  44.         }  
  45.   
  46.         /** 
  47.          * 给用户添加权限用用户权限和要添加的权限|(按位或) 操作再覆盖之前权限值 
  48.          */  
  49.         System.out.println();  
  50.         if ((userb & u) == u) {  
  51.             System.out.println("用户b有更新权限");  
  52.         } else {  
  53.             System.out.println("用户b没有更新权限");  
  54.         }  
  55.   
  56.         System.out.println("==>给用户b添加更新权限");  
  57.         userb = userb | u;  
  58.   
  59.         if ((userb & u) == u) {  
  60.             System.out.println("用户b有更新权限");  
  61.         } else {  
  62.             System.out.println("用户b没有更新权限");  
  63.         }  
  64.   
  65.         /** 
  66.          * 取消用户某种权限,用用户权限和要取消的权限按位取反后进行按位 操作,再覆盖之前权限值 
  67.          */  
  68.         System.out.println();  
  69.         if ((usera & r) == r) {  
  70.             System.out.println("用户a有查询权限");  
  71.         } else {  
  72.             System.out.println("用户a没有查询权限");  
  73.         }  
  74.   
  75.         System.out.println("==>取消用户a的查询权限");  
  76.         usera = usera & (~r);  
  77.   
  78.         if ((usera & r) == r) {  
  79.             System.out.println("用户a有查询权限");  
  80.         } else {  
  81.             System.out.println("用户a没有查询权限");  
  82.         }  
  83.     }  
  84.   
  85. }  
         * @author 李文锴
	 */
	public static void main(String[] args) {

		/**
		 * 四种权限 ,当前定义为int,以下二进制表示只取后四位作说明
		 */

		// 添加
		int c = 1;// ...0001=2^0
		// 查询
		int r = 2;// ...0010=2^1
		// 修改
		int u = 4;// ...0100=2^3
		// 删除
		int d = 8;// ...1000=2^4

		/**
		 * 
		 * 大家可以观察四种权限的二进制表示的规律 ,都是2的N次方,
		 * 就表示本身,添加权限有最后一位为其它为0,查询倒数第二位为1其它都为0,修改倒数第三个为1其它都为0,删除倒数第四个为1其它都为0
		 * 
		 */

		/**
		 * 这样表示有哪种权限时可以用 |(按位或) 操作
		 * 
		 */

		// 用户A有添加和修改权限
		int usera = c | r | u;

		// 用户B有添加和删除权限
		int userb = c | d;

		/**
		 * 判断用户是否有某种权限用用户权限和要判断的权限进行 &(按位与) 操作,结果为要判断的权限值时表示用户有此权限,否则没有此权限
		 */
		System.out.println();
		if ((usera & u) == u) {
			System.out.println("用户a有更新权限");
		} else {
			System.out.println("用户a没有有更新权限");
		}

		/**
		 * 给用户添加权限用用户权限和要添加的权限|(按位或) 操作再覆盖之前权限值
		 */
		System.out.println();
		if ((userb & u) == u) {
			System.out.println("用户b有更新权限");
		} else {
			System.out.println("用户b没有更新权限");
		}

		System.out.println("==>给用户b添加更新权限");
		userb = userb | u;

		if ((userb & u) == u) {
			System.out.println("用户b有更新权限");
		} else {
			System.out.println("用户b没有更新权限");
		}

		/**
		 * 取消用户某种权限,用用户权限和要取消的权限按位取反后进行按位 操作,再覆盖之前权限值
		 */
		System.out.println();
		if ((usera & r) == r) {
			System.out.println("用户a有查询权限");
		} else {
			System.out.println("用户a没有查询权限");
		}

		System.out.println("==>取消用户a的查询权限");
		usera = usera & (~r);

		if ((usera & r) == r) {
			System.out.println("用户a有查询权限");
		} else {
			System.out.println("用户a没有查询权限");
		}
	}

}

二进制和十进制之间的转换

  1. package test;  
  2.   
  3. public class Trans {  
  4.   
  5.     public static void main(String[] args) {  
  6.         int bit = 7;  
  7.         System.out.println(Integer.toBinaryString(bit)); // 十进制转二进制  
  8.   
  9.         Integer it = Integer.valueOf("111"2);  
  10.         System.out.println(it);// 转换为10进制结果  
  11.     }  
  12. }  
package test;

public class Trans {

	public static void main(String[] args) {
		int bit = 7;
		System.out.println(Integer.toBinaryString(bit)); // 十进制转二进制

		Integer it = Integer.valueOf("111", 2);
		System.out.println(it);// 转换为10进制结果
	}
}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值