Python中实现真正的按位取反运算

文章面向对象:对原理和编程不大有兴趣,只是需要用python实现一些运算功能的非计算机学生或从业者。大佬慎看防止血压拉高

目录

    • 运算代码
    • 实例说明

运算代码

x=~x&0xFF

num是一个不大于255的十进制正数(负数的我不需要,所以我也没研究)
计算结果也是十进制的数
&右边的0xFF会决定计算结果的比特位。如果要得到正确的计算结果,两边的数据比特位应该相同
例如1000对应的十六进制是0xFC17,16比特位的,这时候求反就应该改成

x=~x&0xFFFF

实例说明

例如求58的反:
Python中实现真正的按位取反运算_第1张图片
当x大于255时,想要得到正确的数字,就要修改一下代码
把0xFF换成0xFFFF或者更高,取决于x这个数占用的比特位。
(C语言基础会讲的知识,数据精度问题)
总之就是&两边的比特位要对应
**如果&右边保持为0xFF,但x大于了255,得到的结果则只有低位(如下图)
**Python中实现真正的按位取反运算_第2张图片而实际上1000取反应该得到的十六进制表示是 ‘0xFC 17’
把完整的16比特位的FC17截断剩下17
(之所以这里用十六进制表示,是因为&右边对应的是16进制,这样看会更清楚。实际上取反运算是根据二进制表示运行的,那些也不重要,反正知道可以这样算就OK啦!)

你可能感兴趣的:(python,python)