符号 | 描述 | 运算规则 |
---|---|---|
& | 与 | 两个位都为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)