二进制 位与(或)使用

         平时开发时状态判断比较麻烦,有时数据库可能会设置多个字段或一个字段多个值来满足要求。管理维护太繁琐,最近项目中需要判断角色权限,我们就用二进制位(8位)来设置判断。

         当然上述所说与标题里的位与(或)没多大关系,接下来慢慢分析二进制位与(或)如何用于用户权限管理。

         假如:    1:权限1;2:权限2;4:权限3;8:权限4……

                         int num=1|2    // num权限值( 拥有 权限1和权限2)

         那么如何是否有权限3, so  可以使用num&4判断结果是否大于0(大于0或等于4则具有权限3否则没有该权限)

         上述列子:

         位或:1|2------->   0001    --->权限1

                                     0010    ---->权限2

                                  -----------

                                     0011    ----->num

        

          位与:num&3-->  0011  ---->num                                                  位与:num&2 ---> 0011 ----->num

                                     0100  ---->权限3                                                                            0010 ----->权限2

                                ----------------                                                                                     ----------------

                                     0000 ------>0(没有权限)                                                              0010 ----->权限2 (有权限

          结果很明显用起来相当方便,更重要的是sql语句也支持位操作,以前确实忽略了位运算。

学无先后,达者为师
原文地址:https://www.cnblogs.com/seanchang/p/5202739.html