位运算在 C# 中能直接操作整数的二进制位,常用于性能敏感场景(如游戏、嵌入式、高频计算)和内存受限环境。它不依赖高级抽象,执行快、开销低,还能用单个整数紧凑表示多个布尔状态。
常用位运算符及典型用途
C# 支持标准位运算符:
&(与)、
|(或)、
^(异或)、
~(取反)、
(左移)、<code>>>(右移)。它们都作用于整型(
int、
uint、
long等),不能直接用于
bool或引用类型。
x & 1快速判断奇偶:结果为 1 是奇数,0 是偶数
x & (x - 1)清除最低位的 1 —— 常用于检查是否为 2 的幂(结果为 0 且 x ≠ 0)
flags |= FlagEnum.OptionA设置标志位(配合
[Flags]枚举)
value 等价于乘以 8,<code>value >> 2等价于除以 4(仅适用于无符号或非负数)
用 [Flags] 枚举管理多状态
比一堆
bool字段更省内存,也比单独属性更易组合和查询。关键点是枚举值必须是 2 的幂(1, 2, 4, 8…),并加上
[Flags]特性。
<font size="2"><pre class="brush:php;toolbar:false;">[Flags]
public enum FileAccess
{
None = 0,
Read = 1,
Write = 2,
Execute = 4,
All = Read | Write | Execute
}
设置多个权限:var perm = FileAccess.Read | FileAccess.Write检查是否包含某权限:
if ((perm & FileAccess.Read) == FileAccess.Read)或更简洁地用
perm.HasFlag(FileAccess.Read)(注意:后者有装箱开销,高频场景建议用位与) 移除权限:
perm &= ~FileAccess.Write
位字段(Bit Fields)模拟——手动打包布尔值
C# 不支持 C 风格的 bit-field 语法,但可用整型 + 位运算模拟,把 32 个布尔值压缩进一个
int。 定义掩码:
const int DirtyMask = 1 (第 0 位)、<code>const int ValidMask = 1 (第 1 位)设值:
state |= DirtyMask;取值:
bool isDirty = (state & DirtyMask) != 0;清零:
state &= ~DirtyMask;
适合配置项、状态机、网络协议包解析等对空间敏感的场景。
注意事项和性能提示
位运算虽快,但可读性低,过度使用反而增加维护成本。应优先保证逻辑清晰,再考虑优化。
右移有符号整数(int)会算术右移(补符号位),无符号(
uint)是逻辑右移(补 0) 避免在浮点数、字符串、对象上强行用位运算——编译不通过,也不合理 调试时可用
Convert.ToString(x, 2)查看二进制形式(注意正数补前导零,负数显示补码) 现代 CPU 对位运算和普通算术运算的性能差异极小,真正瓶颈通常在内存访问或算法复杂度,别过早优化
基本上就这些。用对地方,位运算是轻量又强大的工具;滥用则得不偿失。
