我们在社会上有心把本身弄得狼狈好笑,仍然是因为虚荣太过,想从人们的恶意中窃取康乐;别人怕以产生这种恶意,本来也是因为我们激起他们的的嫉妒所致。根蒂根基概念 只求取乐,欢欣之后,欲念消退,所谓恋情也就完了。这是天然的分界线,不克不及超越,只有真正的恋情才是无穷无量的。 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 } } 应用二进制进行权限或状况把握 package test; public class Test { /** * @param args */ 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没有查询权限"); } } } 二进制和十进制之间的转换 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进制成果 } } |
|