老生常談PHP位運算的用途

2022-09-28 18:45:15 字數 2703 閱讀 2393

在實際應用中可以做使用者許可權的應用

我這裡說到的許可權管理辦法是乙個普遍採用的方法,主要是使用到」位執行符」操作,& 位與運算子、| 位或執行符。參與運算的如果是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...