在實際應用中可以做使用者許可權的應用
我這裡說到的許可權管理辦法是乙個普遍採用的方法,主要是使用到」位執行符」操作,& 位與運算子、| 位或執行符。參與運算的如果是10進製數,則會被轉換至2進製數參與運算,然後計算結果會再轉換為10進製數輸出。
它的許可權值是這樣的
2^0=1,相應2進數為」0001″(在這裡^我表示成」次方」,即:2的0次方,下同)
2^1=2,相應2進程式設計客棧數為」0010″
2^2=4,相應2進數為」0100″
2^3=8,相應2進數為」1000″
要判斷乙個數在某些數範圍內就可以使用 & 運算子(數值從上面的表中得來)
如:7=4|2|1 (你也可以簡單理解成7=4+2+1)
用 & 來操作,可以知道7&4、7&2、7&1都是真的,而如果7&8則是假的
&、| 不熟悉的就要去查查手冊,看看是怎麼用的了
下面來看例子吧:
// 賦予許可權值-->刪除:8、上傳:4、寫入:2、唯讀:1
define(「mdelete」,8);
define(「mupload程式設計客棧」,4);
define(「mwrite」,2);
define(「mread」,1);
//vvvvvvvvvvvvv使用說明vvvvvvvvvvvvv
//部門經理的許可權為(假設它擁有此部門的所有許可權),| 是位或執行符,不熟悉的就查查資料
echo mdelete|mupload|mwrite|mread ,」
「;// 相當於是把上面的許可權值加起來:8+4+2+1=15
// 設我只有 upload 和 read 許可權,則
echo mupload|mread ,」www.cppcns.com
「;//相當於是把上傳、唯讀的許可權值分別相加:4+1=5
/**賦予它多個許可權就分別取得許可權值相加,又比如某位員工擁有除了刪除外的許可權其餘都擁有,那它的許可權值是多少?
*應該是:4程式設計客棧+2+1=7
*明白了怎麼賦值給許可權吧?
*///^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
//判斷某人的許可權可用,設許可權值在$key中
/**判斷許可權用&位與符,
*/$key = 13;//13=8+4+1
if($key & mdelete) echo 「有刪除許可權
「; //8
if($key & mupload) echo 「有上傳許可權
「; //4
$a=$key & mwrite; echo 「有寫許可權
「.$a; //無此許可權
if($key & mread) echo 「有讀許可權
「; //1
?>
ok,許可權分值的這其中乙個演算法就是這樣的,可以說是簡單高效。也不知大家明白沒有,不明白也沒關係,記住例子就行了。前提就是做好許可權值的分布,即那個1、2、4、8、16….(這裡還有個順序問題,越高階的許可權就要越高的許可權值,比如上面的例子所演示的刪除許可權)。有了許可權分布表就可以確定給某個人什麼許可權了,你簡單的理解成要哪個許可權就加上相應的許可權值吧。
這個方法很好用的,缺點就是如果許可權分布得細的話,那麼許可權值會越來越大,你自己想想,2的幾次方、如果所有的許可權都要則是全部相加。不過對於一般的許可權來說這個已經足夠了。
下面是些簡單應用舉例
(1) 判斷int型變數a是奇數還是偶數
a&1 = 0 偶數
a&1 = 1 奇數
(2) 取int型變數a的第k位 (k=0,1,2……sizeof(int)),即a>>k&1
(3) 將int型變數a的第k位清0,即a=a&~(1<
(4) 將int型變數a的第k位置1, 即a=a|(1<
(5) int型變數迴圈左移k次,即a=a<>16-k (設sizeof(int)=16)
(6) int型變數a迴圈右移k次,即a=a>>k|a<<16-k (設sizeof(int)=16)
(7)整數的平均值
對於兩個整數x,y,如果用 (x+y)/2 求平均值,會產生溢位,因為 x+y 可能會大於int_max,但是我們知道它們的平均值是肯定不會溢位的,我們用如下演算法:
int **erage(int x, int y)程式設計客棧 //返回x,y 的平均值
(8)判斷乙個整數是不是2的冪,對於乙個數 x >= 0,判斷他是不是2的冪
boolean power2(int x)
(9)不用temp交換兩個整數
void swap(int x , int y)
(10)計算絕對值
int abs( int x )
(11)取模運算轉化成位運算 (在不產生溢位的情況下)
a % (2^n) 等價於 a & (2^n – 1)
(12)乘法運算轉化成位運算 (在不產生溢位的情況下)
a * (2^n) 等價於 a<< n
(13)除法運算轉化成位運算 (在不產生溢位的情況下)
a / (2^n) 等價於 a>> n
例: 12/8 == 12>>3
(14) a % 2 等價於 a & 1
(15) if (x == a) x= b;
else x= a;
等價於 x= a ^ b ^ x;
(16) x 的 相反數 表示為 (~x+1)
在32位系統上不要右移超過32位,不要在結果可能超過 32 位的情況下左移
本文標題: 老生常談php位運算的用途
本文位址:
老生常談session,cookie的區別,安全性
一,為什麼session,cookie經常會有人提到 做web開發的人基本上都會用session和cookie,但是僅僅只是會用,並不知道session和cookie的真正的工作原理,都只是憑著感覺來猜測。web開發者只要利用它們來完成工作就行了,所以每個人的理解基本都會有大同小異,我想這就是ses...
老生常談session cookie的區別 安全性
一,為什麼session,cookie經常會有人提到 做web開發的人基本上都會用session和cookie,但是僅僅只是會用,並不知道session和cookie的真正的工作原理,都只是憑著感覺來猜測。web開發者只要利用它們來完成工作就行了,所以每個人的理解基本都會有大同小異,我想這就是ses...
老生常談 與equals的區別
最近在研究string,看到面試題有一題是 與equals的區別的題目。關於 與equals的區別相信大家很熟悉了,包括我也看到也是腦中一閃而過,比較的是位址,equals比較的是內容。真是這樣嗎?或者說能具體或深入的解釋下嗎?如果被面試官這樣問,會如何作答呢?由於最近看了string和object...