Maison > développement back-end > tutoriel php > Résumé des conseils sur l'utilisation des opérateurs de bits PHP que vous ne connaissez pas

Résumé des conseils sur l'utilisation des opérateurs de bits PHP que vous ne connaissez pas

伊谢尔伦
Libérer: 2023-03-10 22:08:02
original
1535 Les gens l'ont consulté

La méthode

de gestion des autorisations est une méthode couramment utilisée, utilisant principalement l'opération "bit opérateur", le & bit et l' opérateur , bit ou opérateur. Si le nombre impliqué dans l'opération est un nombre décimal, il sera converti en nombre binaire pour participer à l'opération, puis le résultat du calcul sera converti en nombre décimal et sorti.

Sa valeur de permission est la suivante :

2^0=1, et le nombre binaire correspondant est "0001" (ici ^ est exprimé en "puissance", soit : 2 0ème puissance , le même ci-dessous)

2^1=2, le nombre 2-aire correspondant est "0010"
2^2=4, le nombre 2-aire correspondant est "0100"
2 ^3 = 8, le nombre binaire correspondant est "1000"

Pour déterminer si un nombre se situe dans une certaine plage de nombres, vous pouvez utiliser l'opérateur & (la valeur est obtenue à partir du tableau ci-dessus)

Par exemple : 7=4|2|1 (Vous pouvez aussi simplement le comprendre comme 7=4+2+1)

Utilisez & pour fonctionner, vous pouvez savoir que 7&4, 7&2, 7&1 sont tout est vrai, et si 7&8 alors c'est faux

&, | Si vous ne le connaissez pas, vous devriez consulter le manuel pour voir comment il est utilisé

Exemple de description :

<?php
// 赋予权限值-->删除: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
?>
Copier après la connexion

OK, autorisations L'un des algorithmes de notation est comme celui-ci, que l'on peut qualifier de simple et efficace. Je ne sais pas si vous comprenez ou non. Cela n’a pas d’importance si vous ne le comprenez pas. Le principe est de bien répartir les valeurs d'autorisation, c'est-à-dire 1, 2, 4, 8, 16... (Il y a aussi un problème d'ordre ici. Plus l'autorisation est élevée, plus la valeur d'autorisation est élevée, comme le suppression démontrée dans l’exemple ci-dessus). Avec le tableau de distribution des autorisations, vous pouvez déterminer quelles autorisations sont accordées à une personne. Vous pouvez simplement comprendre quelles autorisations vous souhaitez, ajoutez simplement les valeurs d'autorisation correspondantes.

Cette méthode est très simple à utiliser. L'inconvénient est que si les autorisations sont réparties finement, la valeur de l'autorisation deviendra de plus en plus grande. Pensez-y par vous-même, combien de puissances de 2, si toutes les autorisations. sont nécessaires ? Additionnez le tout. Mais pour les autorisations générales, cela suffit.

Opération sur les bitsConseils

1. Obtenez les valeurs maximales et minimales du type INT
Valeur maximale :

~ (1 << 31)

Valeur minimale :

(1 << 31)

Opération multiplier par 2 et diviser par 2. opération
Multiplier par 2 :

$n << 1

Diviser par 2 :

$n >> 3. Multiplier Diviser la somme de 2 élevé à la puissance m et de 2 élevé à la puissance m
par 2 élevé à la puissance m :

$n << $m

divisé par 2 m Puissance :

$n >> $m

4 Déterminer la parité d'un entier

($n & 1) == 1.

5. Échangez deux nombres sans variables temporaires

$a ^= $b
$b ^=
$a ^= $b;
6. De bas en haut, prenez le mois de n


retour
($n >> ($m-1)) & 1; 🎜>7 .De la position basse à la position haute. Retourner la position 1 de n
retourner $n | (1 << ($m-1));
8. position en position haute, renvoie la mième position de n à 0

return $n & ~(1 << ($m-1));

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal