符号描述运算规则
&两个位都为1时,结果才为1
|两个位都为0时,结果才为0
^异或两个位相同为0,相异为1
~取反0变1,1变0
<<左移各二进位全部左移若干位,高位丢弃,低位补0
>>右移各二进位全部右移若干位,对无符号数,高位补0,有符号数,各编译器处理方法不一样,有的补符号位(算术右移),有的补0(逻辑右移)

 

算术上,一个 x<<n 左移运算等价于乘以$2^n$,一个 x>>n 右移运算等价于除以$2^n$。

在 x<<n 和 x>>n 移位运算中,n必须是无符号数;x可以是有符号或无符号数。有符号数的右移运算会用符号位的值填充左边空缺的bit位。

 

详见:gopl3.1整型章节 的位运算部分

 

位移运算有用在:错误处理的几种方法(https://blog.csdn.net/chushoufengli/article/details/103970891)中的 time.Second << uint(tries)