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:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
|
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&~(1<
<> ;
(4) Change int Die k-te Position der Typvariablen a ist 1, das heißt a=a|(1<
<>
(5) int type Die Variable wird k-mal zyklisch nach links verschoben, d. h. a=a<>16-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|a<< ;16-k (angenommen, sizeof(int)=16)
(7) Durchschnitt ganzer Zahlen
Für Zwei Ganzzahlen x, y. Wenn Sie (x+y)/2 zur Berechnung des Durchschnitts verwenden, kommt es zu einem Überlauf, da x+y größer als INT_MAX sein kann, aber wir wissen, dass ihr Durchschnittswert definitiv nicht überläuft. Wir verwenden den folgenden Algorithmus :
1 2 3 4 5 6 7 |
|
(8) Beurteilung Ob eine ganze Zahl eine Potenz von 2 ist, für eine Zahl x >= 0, bestimmen Sie, ob dies der Fall ist ist eine Potenz von 2 >(9) Tausche zwei ganze Zahlen ohne Temp aus
1 2 3 4 5 6 7 |
|
(10) Berechnen Sie den Absolutwert
1 2 3 4 5 6 7 8 9 10 11 |
|
(11) Modulo-Operation wird in Bit-Operation umgewandelt (ohne Überlauf)
1 2 3 4 5 6 7 8 9 10 11 |
|
(12) Multiplikationsoperationen werden in Bitoperationen umgewandelt (ohne Überlauf)
1 |
|
(13) Divisionsoperation wird in Bitoperation umgewandelt (ohne Überlauf)
1 |
|
(14) a % 2 ist äquivalent zu a & 1
1 2 |
|
(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!