上QQ阅读APP看书,第一时间看更新
2.5 位运算实战演练1
2.5.1 给定整型数a,设置a的bit3,保证其他位不变
分析:将整数a和bit3为1,其余bit为0的数进行位或运算即可得到结果。
❶构造bit3为1的数。
1<<3
❷然后和整数a相位或并且赋值给a。
a = a | (1<<3);或者a |= (1<<3);
2.5.2 给定整型数a,设置a的bit3~bit7,保持其他位不变
分析:构造数的bit3~bit7为1。
❶构造bit3~bit7为1的数。
0x1f<<3
❷和整数a相位或并赋值给a。
a = a | (0x1f<<3) 或者a |= (0b11111<<3);
2.5.3 给定整型数a,清除a的bit15,保证其他位不变
分析:将整数a和一个bit15为0,其余bit位为1的数进行位与运算即可得结果。
❶构造bit15为0,其余位为1的数。在构造这个数之前,通过2.3节的分析需要先构造bit15为1,其余位为0的数,然后位取反即可。
~(1<<15)
❷和整数a相位与并赋值给a。
a = a & (~(1<<15));或者a &= (~(1<<15));
2.5.4 给定整型数a,清除a的bit15~bit23,保持其他位不变
分析:将整数a和一个bit15~ bit23为0,其余bit位为1的数进行位与运算即可得结果。
❶构造bit15~ bit23为0,其余位为1的数。
~(0x1ff<<15)
❷和整数a位与并赋值给a。
a = a & (~(0x1ff<<15));或者a &= (~(0x1ff<<15));
2.5.5 给定整型数a,取出a的bit3~bit8
分析:先将这个数bit3~bit8不变,其余位全部清零;再将其右移3位得到结果;想明白了上面的两步算法,再将其转为C语言实现即可。
❶构造bit3~ bit8为1,其余位为0的数。
0x3f<<3
❷和整数a位与并赋值给a。
a &= (0x3f<<3);
❸再将a右移3位。
a >>= 3;
2.5.6 用C语言给寄存器a的bit7~bit17赋值937(其余位不受影响)
分析:我们只需要将bit7~bit17全部清零,然后再将937设置到bit7~bit17位,这个过程中必须注意的一点就是不能影响其他位。
❶构造bit7~bit17为0,其余位为1的数。
~(0x7ff<<7)
❷bit7~bit17清零。
a &= ~(0x7ff<<7);
❸构造bit7~bit17为937,其余位为0的数。
937<<7
❹将937写入a的bit7~bit17。
a |= (937<<7);