FLAG_Mask = 0x00FFFFFF = 0000 0000 1111 1111 1111 1111 1111 1111
通过与操作符 &
,所有不在 FLAG_Mask
掩码范围内的位(高 8 位)都被置为 0,而保留了低 24 位。以下是具体的操作细节:
1. 保留低 24 位
I2C_FLAG
是一个 32 位无符号整数,FLAG_Mask
也同样是一个 32 位值,其中只有低 24 位是 1,高 8 位是 0。因此,I2C_FLAG &= FLAG_Mask;
只会保留 I2C_FLAG
的低 24 位,而将高 8 位清零。
2. 避免影响寄存器地址的高 8 位
当你在右移 I2C_FLAG
以确定它属于 SR1
或 SR2
时,确保 I2C_FLAG
的高 8 位是 0 是必要的,因为这些高位可能会在位移操作后影响到最终的计算结果。
3. 代码逻辑示例
假设我们有以下的代码片段:
I2C_FLAG = 0x10008000 = 0001 0000 0000 0000 1000 0000 0000 0000
FLAG_Mask = 0x00FFFFFF = 0000 0000 1111 1111 1111 1111 1111 1111
通过 &
操作后:
I2C_FLAG &= FLAG_Mask
I2C_FLAG = 0000 0000 1000 0000 0000 0000 = 0x00800000
4. 实际意义
- 筛选寄存器标志位:使用
FLAG_Mask
将I2C_FLAG
的高 8 位清零,仅保留低 24 位,以确保这些位位于实际寄存器标志位的范围内(SR1
和SR2
)。 - 消除错误干扰:在计算或比较操作中,清除高位以防止由于高位误差导致的错误。