位运算应用

public class Permission {

    // 是否允许查询,二进制第1位,0表示否,1表示是
    public static final int ALLOW_SELECT = 1 << 0; // 0001 = 1

    // 是否允许新增,二进制第2位,0表示否,1表示是
    public static final int ALLOW_INSERT = 1 << 1; // 0010 = 2

    // 是否允许修改,二进制第3位,0表示否,1表示是
    public static final int ALLOW_UPDATE = 1 << 2; // 0100 =4

    // 是否允许删除,二进制第4位,0表示否,1表示是
    public static final int ALLOW_DELETE = 1 << 3; // 1000 = 8
    // 存储目前的权限状态
    private int flag;

    // 设置用户的权限
    public void setPer(int per) {
        flag = per;
    }

    public int getPer() {
        return flag;
    }

    // 增加用户的权限(1个或者多个)
    public void enable(int per) {
        flag = flag | per;
    }

    // 删除用户的权限(1个或者多个)
    public void disable(int per) {
        flag = flag & ~per;
    }

    // 判断用户的权限
    public boolean isAllow(int per) {
        return ((flag & per) == per);
    }

    // 判断用户没有的权限
    public boolean isNotAllow(int per) {
        return ((flag & per) == 0);
    }

    public static void main(String[] args) {
        int flag = 15;
        Permission permission = new Permission();
        permission.setPer(flag);
        permission.enable(ALLOW_INSERT);
        System.out.println(permission.getPer());
        permission.disable(ALLOW_DELETE | ALLOW_INSERT);
        System.out.println("select = " + permission.isAllow(ALLOW_SELECT));
        System.out.println("update = " + permission.isAllow(ALLOW_UPDATE));
        System.out.println("insert = " + permission.isAllow(ALLOW_INSERT));
        System.out.println("delete = " + permission.isAllow(ALLOW_DELETE));

    }
}

对于2元状态(true或者false)可以用2进制(0/1)来存储,每一位上都对应种属性的true/false,最多可以存储31种属性的状态。

增加 删除 判断某种属性可以按上述代码的算法实现。

好处:大大节约了存储空间,和运算时间,一个2进制数就可以最多包含31种属性的状态

posted @ 2018-11-29 08:56  sagan15  阅读(107)  评论(0编辑  收藏  举报