Go语言位运算符直接操作二进制位,适用于性能敏感场景。1. 基本运算符包括&(与)、|(或)、^(异或)、&^(清零)、<<(左移)、>>(右移)。2. 常用技巧:n&1判断奇偶,n<<k实现n*2^k,异或交换两数,n&(n-1)清除最低位1,n&(-n)提取最低位1。3. 可用于设置(n|=(1<<i))、清除(n&^=(1<<i))、判断(n&(1<<i)!=0)特定位。4. 结合iota定义状态标志,如权限控制(Read|Write),通过位与检测权限。熟练使用可提升效率与代码简洁性。

Go语言中的位运算符直接操作整数的二进制位,常用于性能敏感场景、状态标记、权限控制和底层开发。掌握这些运算符及其技巧,能写出更高效、简洁的代码。
基本位运算符
Go支持以下几种位运算符,适用于整型数据:
- &:按位与,同1为1
- |:按位或,有1为1
- ^:按位异或,不同为1
- &^:位清零(a &^ b 等价于 a & (~b))
- <<:左移,高位丢弃,低位补0
- >>:右移,正数补0,负数补符号位
示例:
a := 5 // 101
b := 3 // 011
a & b // 001 → 1
a | b // 111 → 7
a ^ b // 110 → 6
a &^ b // 101 & (~011) = 101 & 100 → 100 → 4
常用操作技巧
判断奇偶性
利用最低位判断,比取模更快。
立即学习“go语言免费学习笔记(深入)”;
n & 1 == 1 → 奇数
n & 1 == 0 → 偶数
快速乘除2的幂
左移n位相当于乘以2^n,右移相当于除以2^n(整数除法)。
n << 1 → n * 2
n >> 1 → n / 2(向下取整)
n << 3 → n * 8
交换两个整数
不用额外变量,利用异或特性。
a ^= b
b ^= a
a ^= b // a和b完成交换
清除最低位的1
常见于统计1的个数或树状数组。
n & (n - 1) 会将n的最低位1清零
例如:6 (110) → 6 & 5 = 110 & 101 = 100 → 4
提取最低位的1
获取最右边的1所代表的值。
n & (-n)
例如:12 (1100),-12在补码中为...0100,12 & (-12) = 100 → 4
设置、清除、判断某一位
常用于标志位管理。
- 设置第i位:n |= (1 << i)
- 清除第i位:n &^= (1 << i)
- 判断第i位是否为1:(n & (1 << i)) != 0
状态标记与权限控制
用一个整数表示多个布尔状态。
const (
Read = 1 << iota // 1
Write // 2
Execute // 4
)
perms := Read | Write // 拥有读写权限
hasRead := (perms & Read) != 0 // true
小结
位运算在Go中高效且实用,尤其适合处理标志位、优化数学运算和实现底层逻辑。熟练使用这些技巧,能提升代码性能和可读性。基本上就这些,不复杂但容易忽略。










