我们在社会上有心把本身弄得狼狈好笑,仍然是因为虚荣太过,想从人们的恶意中窃取康乐;别人怕以产生这种恶意,本来也是因为我们激起他们的的嫉妒所致。根蒂根基概念
只求取乐,欢欣之后,欲念消退,所谓恋情也就完了。这是天然的分界线,不克不及超越,只有真正的恋情才是无穷无量的。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进制成果
}
}