python - 在 Python 中使用 0xFFFFFFFF 掩码检测 int32 溢出?

标签 python python-3.x binary overflow sign

我发现在 Python 中使用 0xFFFFFFFF 掩码检测 int32 溢出可能适用于正数。

表达式:

x & 0xFFFFFFFF == x

如果 x 不溢出且 x 大于 0,将返回 True

但是,这个表达式不适用于负整数,例如:

(-7 & 0xFFFFFFFF) == -7

将返回 False,但 -7 不应溢出 int32 范围..

有没有人知道为什么这种方法不适用于 -7 以及如何让它起作用?

最佳答案

那是因为 Python 不考虑数字的任何固定宽度。所以您没有任何符号位,就像我们为 C/C++ 语言所拥有的那样(最高有效位)。换句话说,当您在负数和 0xffff 之间执行位与时,结果是一个大的正数而不是负数:

>>> print(-7 & 0xFFFF)
65529
>>> print(-7 & 0xFFFFFFFF)
4294967289
>>> 

确认上述声明:

>>> x = -1
>>> y = -2
>>> z = -4
>>> x.bit_length()
1
>>> y.bit_length()
2
>>> z.bit_length()
3
>>> 

C/C++ 语言中,因为我们对数字有一个固定宽度:

#include <iostream>
#include <string>

int main()
{
  int i = -7 & 0xFFFFFFFF;
  std::cout <<  i;
}

输出是相同的负数(如果我们为 & 运算符的右侧选择正确的长度):

-7 

我猜你需要定义一个函数来瞄准你的目标并传递带有长度的数字。(例如 4 字节或 8 字节)。

像这样:

>>> def isOverflow(num, width=32):
    if num > 0 and num > 2**(width-1) -1 :
        return True
    elif num < 0 and abs(num) > 2**(width-1):
        return True
    return False

或者更高效的版本:

def isOverflow(num, width=32):
    if num > 0:
        if num >> width-1:
            return True
    elif num < 0:
        if abs(num) > (1 << width - 1):
            return True
    return False

工作原理如下:

>>> ================================ RESTART ================================
>>> 
>>> isOverflow(-129,8)
True
>>> isOverflow(-128,8)
False
>>> isOverflow(128,8)
True
>>> isOverflow(127,8)
False
>>> isOverflow(0x7fffffff)
False
>>> isOverflow(0x8fffffff)
True

关于python - 在 Python 中使用 0xFFFFFFFF 掩码检测 int32 溢出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36819849/

相关文章:

Python类-- super 变量

python - 是否可以将 3D 模型导入 pyglet?

python - 如何仅从 Pandas 数据框中提取列标签?

algorithm - 二进制 De-Bruijn 序列中的零和一的总和

python - 如何在 Flask 中实现需要登录的装饰器

python - 用 python 正则表达式从旧字符串计算出的新字符串替换子字符串

python-3.x - 尽管在同一目录中,但 .env 文件内容在 docker compose 构建期间未被替换

python - 在多对多字段中使用 through 属性并遇到 "Non-Unique"字段要求

ios - 二进制拒绝 IOS,启动时崩溃

c - 将 float (弧度角)写入文件时节省空间