以8bit为例:
bit7、bit6、bit5、bit4、bit3、bit2、bit1、bit0
8位倒置计算,
既为:
bit0<->bit7
bit1<->bit6
bit2<->bit5
bit3<->bit6
最终结果:bit0、bit1、bit2、bit3、bit4、bit5、bit6、bit7
第一步:相邻位交换(单bit交换)
bit7<->bit6
bit5<->bit4
bit3<->bit2
bit1<->bit0
对应代码:data = ((data & 0x55) << 1) | ((data & 0xaa) >>1)
结果:bit6、bit7、bit4、bit5、bit2、bit3、bit0、bit1
第二步:相邻双位交换(双bit交换)
bit6、bit7<->bit4、bit5
bit2、bit3<->bit0、bit1
对应代码:data = ((data & 0x33) << 2) | ((data & 0xcc) >> 2)
结果:bit4、bit5、bit6、bit7、bit0、bit1、bit2、bit3
第三步:高四位、低四位交换
bit4、bit5、bit6、bit7<->bit0、bit1、bit2、bit3
对应代码:data = (data << 4) | (data >> 4)
结果:bit0、bit1、bit2、bit3、bit4、bit5、bit6、bit7
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。