Maison > développement back-end > tutoriel php > Exemples résumant les compétences d'utilisation des opérateurs de bits PHP

Exemples résumant les compétences d'utilisation des opérateurs de bits PHP

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

Illustré à travers un exemple :

<?php
//1.位运算符两边的值必须是整形和浮点型,当是其它类型的值时会先转换成整形和浮点型再来参与位运算;
 //而逻辑运算符两边参与运算的值必须是布尔型;
 var_dump(12&13);//输出 int 12
 //12转换成32位的二进制数为:00000000 00000000 00000000 00001100
 //13转换成32位的二进制数为:00000000 00000000 00000000 00001101
 //按位运算后得到的值为      00000000 00000000 00000000 00001100 ,等于12
 
 var_dump(&#39;A&#39;&&#39;a&#39;);//输出string &#39;A&#39;;因为A=65,a=97
 
 var_dump(&#39;A&#39;&97);//输出int 0;因为字符串A会先转换为整数的0后再参与位运算
 
 //2.位运算与逻辑运算不同没有短路特性
 $a=3;
 $b=10;
 if($a>5&&$b++<100)
 {
     echo "1111111111";
 }
 echo $b."<br>";//输出$b=10,逻辑运算短路,$b没有自加;
 
 if($a>5&$b++<100)
 {
     echo "1111111";
 }
 echo $b."<br>";//输出$b=11,位运算不短路,$b自加;
 
 //3.按位非,按位异或等比较简单,这里不做过多讲叙;现在讲讲按位左移和按位右移动
 var_dump(12>>2);//输出int 3
 var_dump(12<<2);//输出int 48
 //可以发现,左移几位就相当于乘以2的多少次方;按位右移就相当于除以2的多少次方;
 
?>
Copier après la connexion

(1) Déterminer si la variable int a est impaire ou paire

a&1 = 0 pair

a&1 = 1 impair

(2) Prenez le k-ème bit de la variable de type int a (k=0,1,2...sizeof(int)), c'est-à-dire a>>k&1

(3) Changer int Effacer le k-ième bit de la variable de type a à 0, c'est-à-dire a=a&~(1<

<>

(4) Définir le k-ième bit de la variable de type int a à 1, c'est-à-dire a =a|(1<

<>

(5) La variable int est décalée circulairement vers la gauche k fois, c'est-à-dire a=a<>16-k (supposons que sizeof(int) =16)

(6) La variable de type int a est décalée circulairement vers la droite k fois, c'est-à-dire a=a>>k|a<<16-k (supposons que sizeof(int)=16)

(7) Moyenne des entiers

Pour deux entiers x, y, si vous utilisez (x+y)/2 pour trouver la moyenne, un débordement se produira car x+y peut être supérieur à INT_MAX, mais nous savons que leur valeur moyenne ne débordera certainement pas. Nous utilisons l'algorithme suivant :

<🎜. >
int average(int x, int y) //返回X,Y 的平均值 
{ 
    return (x&y)+((x^y)>>1); 
}
Copier après la connexion
(8) Pour déterminer si un entier est une puissance de 2, pour un nombre x >= 0, déterminez Est-ce une puissance de 2

boolean power2(int x) 
{ 
    return ((x&(x-1))==0)&&(x!=0); 
}
Copier après la connexion
(9) Échangez deux entiers sans temp

void swap(int x , int y) 
{ 
   x ^= y; 
   y ^= x; 
   x ^= y; 
}
Copier après la connexion
(10) Calculer la valeur absolue

int abs( int x ) 
{ 
   int y ; 
   y = x >> 31 ; 
   return (x^y)-y ; //or: (x+y)^y 
}
Copier après la connexion
(11 ) l'opération modulo est convertie en opération bit (sans débordement)

a % (2 ^n) est équivalent à a & (2^n – 1)

(12 )L'opération de multiplication est convertie en opération sur bits (sans débordement)

a * (2^n) est équivalent à a<< n

(13) L'opération de division est convertie en opérations au niveau du bit (sans débordement)

a / (2^n) est équivalent à a>>

Exemple : 12/8 == 12>>3

(14) un % 2 équivaut à un & 1

(15) si (x == a) x = b;

else x= a;

Équivalent à x= a ^ b ^ x;

(16) L'opposé de x s'exprime comme (~x+ 1)

N'utilisez pas le Shift droit de plus de 32 bits, ne décalez pas vers la gauche lorsque le résultat peut dépasser 32 bits

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