Go位运算

&       位运算 AND  
|       位运算 OR  
^       位运算 XOR  
&^      位运算 (AND NOT)
<<      左移
>>      右移    

&(AND)

& 运算:相同位的两个数字都为1,则为1;若有一个不为1,则为0。

0000 0100   4
0000 0110   6
---------
0000 0100   4

|(OR)

| 运算:相同位只要一个为1即为1。

0000 0100   4
0000 0110   6
---------
0000 0110   6

^(XOR)

作为二元运算:相同位不同则为1,相同则为0。

0000 0100   4
0000 0110   6
---------
0000 0010   2

作为一元运算:按位取反。
涉及知识点,参考:博文

所有正整数的按位取反是其本身+1的负数
所有负整数的按位取反是其本身+1的绝对值
零的按位取反是 -1

0000 0100   4 原码
0000 0100   4 补码
1111 1011   4的补码取反记为 x
1111 1010   x-1 得到反码记为 y
1111 0101   y 取反得到源码,此为最终结果 -5

&^(AND NOT)

&^ 运算:位清空运算,和被运算变量位置有关系。计算x&^y 如果ybit位上的数是0则取x上对应位置的值, 如果ybit位上为1则取结果位上取0

0000 0100   4 记为 x
0000 0110   6 记为 y
---------
0000 0000   0

<< 和 >>

<< 运算:a << b就表示把a转为二进制后左移b位(在后面添b个0)。
>> 运算:a >> b表示二进制右移b位(去掉末b位),相当于a除以2的b次方(取整)。

0000 0100   4
0000 1000   4 << 1 = 8
0001 0000   4 << 2 = 16

0000 0110   6
0000 0011   6 >> 1 = 3
0000 0001   6 >> 2 = 1
原文地址:https://www.cnblogs.com/wuyongqiang/p/11888745.html