Beispiele, die die Verwendungsfähigkeiten von PHP-Bitoperatoren zusammenfassen

伊谢尔伦
Freigeben: 2023-03-10 22:10:01
Original
1746 Leute haben es durchsucht

Anhand eines Beispiels veranschaulicht:

<?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的多少次方;
 
?>
Nach dem Login kopieren

(1) Bestimmen Sie, ob die int-Variable a ungerade oder gerade ist

a&1 = 0 gerade

a&1 = 1 ungerade

(2) Nehmen Sie das k-te Bit der Variablen vom Typ int a (k=0,1,2...sizeof(int)), also a>>k&1

(3) Ändern Sie int. Löschen Sie das k-te Bit der Typvariablen a auf 0, d k-tes Bit der Variablen vom Typ int a auf 1, d. h. a =a|(1<

<>

(5) Die int-Variable wird kreisförmig nach links verschoben k-mal, d. a=a>>k|a<<16-k (angenommen, sizeof(int)=16)

(7) Durchschnitt ganzer Zahlen

Für zwei ganze Zahlen x, y, wenn Wenn Sie (x+y)/2 verwenden, um den Durchschnitt zu ermitteln, tritt ein Überlauf auf, da x+y möglicherweise größer als INT_MAX ist. Wir wissen jedoch, dass ihr Durchschnittswert definitiv nicht überläuft. Wir verwenden den folgenden Algorithmus:

(8) Um zu bestimmen, ob eine ganze Zahl eine Potenz von 2 ist, bestimmen Sie für eine Zahl x >= 0, ob es sich um eine Potenz von 2 handelt

(9) Tauschen Sie zwei ganze Zahlen ohne aus temp

int average(int x, int y) //返回X,Y 的平均值 
{ 
    return (x&y)+((x^y)>>1); 
}
Nach dem Login kopieren

(10) Berechnen Sie den Absolutwert

boolean power2(int x) 
{ 
    return ((x&(x-1))==0)&&(x!=0); 
}
Nach dem Login kopieren

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

void swap(int x , int y) 
{ 
   x ^= y; 
   y ^= x; 
   x ^= y; 
}
Nach dem Login kopieren
a % (2 ^n) ist äquivalent zu a & (2^n – 1)

(12 )Multiplikationsoperation wird in Bitoperation umgewandelt (ohne Überlauf)
int abs( int x ) 
{ 
   int y ; 
   y = x >> 31 ; 
   return (x^y)-y ; //or: (x+y)^y 
}
Nach dem Login kopieren

a * (2^n) ist äquivalent zu a<< n

(13) Divisionsoperation wird in bitweise Operationen umgewandelt (ohne Überlauf)

a / (2^n) ist äquivalent zu a>>

Beispiel: 12/8 == 12>>3

(14) a % 2 entspricht a & 1

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

sonst x= a;

Äquivalent zu x= a ^ b ^ x;

(16) Das Gegenteil von x wird ausgedrückt als (~x+ 1)

Verwenden Sie die rechte Verschiebung nicht um mehr als 32 Bit, verschieben Sie nicht nach links, wenn das Ergebnis 32 Bit überschreiten kann

Das obige ist der detaillierte Inhalt vonBeispiele, die die Verwendungsfähigkeiten von PHP-Bitoperatoren zusammenfassen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!