Heim >Backend-Entwicklung >PHP-Tutorial >Eine detaillierte Diskussion der Verwendung von Bitoperationen in PHP

Eine detaillierte Diskussion der Verwendung von Bitoperationen in PHP

黄舟
黄舟Original
2017-03-13 16:41:37990Durchsuche

Der folgende Editor bringt Ihnen ein Klischee über die Verwendung von PHPBit-Operationen. Der Herausgeber findet es ziemlich gut, deshalb werde ich es jetzt mit Ihnen teilen und es allen als Referenz geben. Folgen wir dem Editor und werfen wir einen Blick darauf.

In praktischen Anwendungen können Benutzerberechtigungen angewendet werden

Die hier erwähnte Methode Berechtigungsverwaltung ist eine häufig verwendete Methode. Verwenden Sie hauptsächlich die Operation „Bit-Operator“, den &-Bit- und den -Operator , |. Wenn die an der Operation beteiligte Zahl eine Dezimalzahl ist, wird sie in eine Binärzahl umgewandelt, um an der Operation teilzunehmen. Anschließend wird das Berechnungsergebnis in eine Dezimalzahl umgewandelt und ausgegeben.

Sein Berechtigungswert ist wie folgt:

2^0=1, die entsprechende zweistellige Zahl ist „0001“ (hier^I Ausgedrückt als „Potenz“, das heißt: 2 hoch 0, das Gleiche unten)

2^1=2, die entsprechende 2-stellige Zahl ist „0010“
2^2=4, die entsprechende 2-äre Zahl Die Zahl ist „0100“
2^3=8, und die entsprechende Binärzahl ist „1000“

Um festzustellen, ob eine Zahl innerhalb eines bestimmten Zahlenbereichs liegt, können Sie Verwenden Sie den &-Operator (der Wert stammt aus der Tabelle oben).

Zum Beispiel: 7=4|2|1 (Sie können es auch einfach als 7=4+2+ verstehen 1)

Mit & können Sie erkennen, dass 7&4, 7&2, 7&1 alle wahr sind, und wenn 7&8 falsch ist

&, | Wenn Sie damit vertraut sind, sollten Sie im Handbuch nachsehen, wie es verwendet wird.

Schauen wir uns ein Beispiel an:


// 赋予权限值-->删除: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 ,”
“;//相当于是把上传、只读的权限值分别相加: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, die Berechtigungsbewertung ist Einer dieser Algorithmen sieht so aus, man kann sagen, dass er einfach und effizient ist. Ich weiß nicht, ob Sie es verstehen oder nicht. Es spielt keine Rolle, ob Sie es nicht verstehen. Die Voraussetzung besteht darin, die Berechtigungswerte gut zu verteilen, d Löschung im obigen Beispiel gezeigt). Mit der Berechtigungsverteilungstabelle können Sie bestimmen, welche Berechtigungen einer Person erteilt werden. Sie können einfach herausfinden, welche Berechtigungen Sie benötigen, indem Sie einfach die entsprechenden Berechtigungswerte hinzufügen.

Diese Methode ist sehr einfach zu verwenden. Der Nachteil besteht darin, dass der Berechtigungswert immer größer wird. Überlegen Sie selbst, wie viele Zweierpotenzen es gibt sind erforderlich? Addieren Sie alles. Für allgemeine Berechtigungen reicht dies jedoch aus.

Im Folgenden finden Sie einige einfache Anwendungsbeispiele

(1) Int-Typ bestimmenVariable a Ist es eine ungerade Zahl oder eine gerade Zahl?

a&1 = 0 Gerade Zahl

a&1 = 1 Ungerade Zahl

(2) Nehmen Sie die Variable vom Typ int a Das k-te Bit (k=0,1,2...sizeof(int)), also a>>k&1

(3) will int type Das k-te Bit der Variablen a wird auf 0 gelöscht, d. h. a=a&~(17a8bc0f8329b8589d316aa5ae3854be8

(5) int type Die Variable wird k-mal zyklisch nach links verschoben, d. h. a=aa8093152e673feb7aba1828c4353209416-k (unter der Annahme von sizeof( int)=16)

(6) Variable vom Typ int Eine Schleife bewegt sich k-mal nach rechts, d. h. a=a>>k|ab3f7326131fcf23f1a15e28f56cfb5b6= 0, bestimmen Sie, ob dies der Fall ist ist eine Potenz von 2 >(9) Tausche zwei ganze Zahlen ohne Temp aus


boolean power2(int x)

{

return ((x&(x-1))==0)&&(x!=0);

}

(10) Berechnen Sie den Absolutwert


void swap(int x , int y)

{

x ^= y;

y ^= x;

x ^= y;

}

(11) Modulo-Operation wird in Bit-Operation umgewandelt (ohne Überlauf)


int abs( int x )

{

int y ;

y = x >> 31 ;

return (x^y)-y ; //or: (x+y)^y

}

(12) Multiplikationsoperationen werden in Bitoperationen umgewandelt (ohne Überlauf)

a % (2^n) 等价于 a & (2^n – 1)

(13) Divisionsoperation wird in Bitoperation umgewandelt (ohne Überlauf)

a * (2^n) 等价于 a<< n

(14) a % 2 ist äquivalent zu a & 1

a / (2^n) 等价于 a>> n
例: 12/8 == 12>>3
(15) if (x == a) x= b;

(16) Das Gegenteil von x wird ausgedrückt als (~x+1) auf 32-Bit-Systemen Nicht um mehr als nach rechts verschieben 32 Bits und verschieben Sie nicht nach links, wenn das Ergebnis 32 Bits überschreiten könnte

Das obige ist der detaillierte Inhalt vonEine detaillierte Diskussion der Verwendung von Bitoperationen in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn