程序設計的過程中,有時需要用若干屬性來表示對某個資源的訪問控制。比如,Linux中文件的可讀、可寫、可執行,代表著三種權限。在程序設計的時候可以定義三個屬性來表示:
private boolean canRead;
private boolean canWrite;
private boolean canExecute;
有另一種更巧妙的方式,便是通過二進制位來實現,比如定義一個long
類型的flag:
private long flag = 0L;
定義權限
p.s. :在Java中long占有64bit,這里為了方便演示,只取其低位的4bit)
0 0 0 0 --> 表沒有任何權限,十進制(falg=0)
0 0 0 1 --> 第1位,表讀權限,十進制(flag=1)
0 0 1 0 --> 第2位,表寫權限,十進制(flag=2)
0 1 0 0 --> 第3位,表執行權限,十進制(flag=4)
設置權限
設置權限的時候,將flag和權限定義的值做“或”操作,得到的值就是設置以后的。比如,下面的例子為flag設置“讀”和“執行”的權限,則需要:
flag = flag | 1;
flag = flag | 4;
即:
0 0 0 0
| 0 0 0 1 --> 讀權限定義的數值
---------
0 0 0 1 --> 十進制(1)具有讀取權限
| 0 1 0 0 --> 執行權限定義的數值
---------
0 1 0 1 --> 十進制(5)具有讀取和執行權限
最終,得到了flag=5,表示具有讀取和執行權限。
解析權限
解析權限的時候,將flag和權限定義的值做“與”操作,得到的值如果等于權限定義的值,則表示有該權限,否則沒有。下面以flag=5為例,解析它都包含什么權限:
0 1 0 1 --> 十進制(5)
& 0 0 0 1 --> 讀權限定義的數值
---------
0 0 0 1 --> 和讀權限定義的數值相等,表示具有讀權限
0 1 0 1 --> 十進制(5)
& 0 0 1 0 --> 寫權限定義的數值
---------
0 0 0 0 --> 和寫權限定義的數值不等,表示沒有寫權限
0 1 0 1 --> 十進制(5)
& 0 1 0 0 --> 執行權限定義的數值
---------
0 1 0 0 --> 和執行權限定義的數值想定,表示具有執行權限
程序實現
為了更直觀,下面用Java來實現以上的過程:
public class BitTest {
private static final long READ = 1;
private static final long WRITE = 1<<1;
private static final long EXECUTE = 1<<2;
public static long setFlag(long... permissionList){
long flag = 0L;
for(long permission : permissionList){
flag |= permission;
}
return flag;
}
public static void printFlag(long flag){
if(flag == 0){
System.out.println("Flag hasn't any permission!");
return;
}
if((flag & READ) == READ){
System.out.println("Flag has READ permission!");
}
if((flag & WRITE) == WRITE){
System.out.println("Flag has WRITE permission!");
}
if((flag & EXECUTE) == EXECUTE){
System.out.println("Flag has EXECUTE permission!");
}
}
public static void main(String[] args) {
long flag = setFlag(READ, EXECUTE);
printFlag(flag);
}
}
main方法中為flag設置了READ
和EXECUTE
權限,并解析flag所包含的權限。運行結果:
Flag has READ permission!
Flag has EXECUTE permission!