zoukankan      html  css  js  c++  java
  • 二进制 位与(或)使用

             平时开发时状态判断比较麻烦,有时数据库可能会设置多个字段或一个字段多个值来满足要求。管理维护太繁琐,最近项目中需要判断角色权限,我们就用二进制位(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语句也支持位操作,以前确实忽略了位运算。

    学无先后,达者为师
  • 相关阅读:
    jQuery事件
    php学习注意事项
    取消php上传2M的限制(windows服务器)
    PHP编程值得注意的细节
    jQuery load()方法特殊用法!
    PHP显示乱码和apache内部编码问题的解决
    定制Apache索引样式
    这么长时间也没有人看看我
    加载php5apache2_2.dll失败的处理方法
    WinXP下的ApachePHPMySQL安装和配置
  • 原文地址:https://www.cnblogs.com/seanchang/p/5202739.html
Copyright © 2011-2022 走看看