java二进制权限_java编程中应用二进制进行权限或状况把握

这篇博客介绍了如何利用二进制位运算来实现权限管理,包括添加、查询、修改和删除权限。通过位或(|)、位与(&)和位非(~)操作,可以方便地进行权限的组合、检查以及撤销。用户权限用二进制表示,每个位对应一种特定的权限,例如添加、查询、修改和删除。通过示例代码展示了如何判断用户是否拥有特定权限以及如何动态修改用户权限。
摘要由CSDN通过智能技术生成

我们在社会上有心把本身弄得狼狈好笑,仍然是因为虚荣太过,想从人们的恶意中窃取康乐;别人怕以产生这种恶意,本来也是因为我们激起他们的的嫉妒所致。根蒂根基概念

只求取乐,欢欣之后,欲念消退,所谓恋情也就完了。这是天然的分界线,不克不及超越,只有真正的恋情才是无穷无量的。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进制成果

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值