按位操作符直接操作二进制位,高效省资源,适用于状态管理、算法优化等;位掩码用单个int存32种布尔状态;常用技巧包括右移替代除法、与运算替代取模、异或交换、奇偶判断、清零最低位1等;广泛用于底层交互与数据解析。

按位操作符直接对整数的二进制位进行操作,效率高、资源省,在底层控制、状态管理、算法优化等场景中不可替代。
高效存储多个开关状态(位掩码)
用一个 int 变量的 32 个比特位,分别表示 32 种独立布尔状态,比用 32 个 boolean 字段或 boolean[] 节省内存且访问更快。
- 定义常量:`final int READ = 1 `final int WRITE = 1 `final int EXECUTE = 1
- 组合权限:`int permissions = READ | WRITE; // 0011`
- 判断权限:`(permissions & READ) != 0 // true`
- 开启/关闭某位:`permissions |= EXECUTE;`(开) 或 `permissions &= ~WRITE;`(关)
快速乘除与取模(2 的幂次)
编译器常自动优化,但显式使用可提升可读性与确定性,尤其在性能敏感代码中。
- 左移 `x
- 右移 `x >> n`(有符号)或 `x >>> n`(无符号)等价于 `x / (2^n)` 向下取整,如 `17 >> 2 → 4`(17 ÷ 4 = 4.25 → 4)
- `x & (n-1)` 在 n 是 2 的幂时等价于 `x % n`,如 `13 & 7 → 5`(13 % 8 = 5)
位运算实现基础算法技巧
避开分支与浮点,提升稳定性和速度,常见于加密、哈希、图形、嵌入式等领域。
立即学习“Java免费学习笔记(深入)”;
- 交换两数(无需临时变量):
a ^= b; b ^= a; a ^= b; - 判断奇偶:`n & 1 == 1` 比 `n % 2 == 1` 更快更直观
- 获取最低位 1 的位置:`Integer.numberOfTrailingZeros(n)` 底层依赖 `n & -n`
- 快速清零最低位 1:`n & (n - 1)`,常用于统计 1 的个数或判断是否为 2 的幂
与硬件/协议/序列化交互
网络字节序解析、设备寄存器配置、压缩数据解包等,都需逐位解析原始字节流。
- 从 4 字节中提取 RGB 值:`int pixel = 0xFFAABBCC;`
`int r = (pixel >> 16) & 0xFF;`
`int g = (pixel >> 8) & 0xFF;`
`int b = pixel & 0xFF;` - 设置 GPIO 引脚:`register |= (1
- 解析 TCP 标志位(SYN、ACK、FIN 等):直接用 `flags & SYN_FLAG` 判断
基本上就这些——不复杂但容易忽略。用对了,代码更轻、更快、更贴近数据本质。










