Python 中的有符号按位算术

发布于 2024-09-29 16:34:06 字数 521 浏览 2 评论 0原文

我被以下 Python 代码卡住了

>>> a = 0xff
>>> b = 1 << 8
>>> ~a & ~b
-512

为什么它是 -512?在二进制表示法中,它应该如下所示:

     a   0 1111 1111   -> 255
     b  01 0000 0000   -> 256

    ~a   1 0000 0000   -> -256
    ~b  10 1111 1111   -> -257

  ~a&~b 00 0000 0000   -> 0

我期望 0 与 C 中的signed int 一样:

signed int a = 0xff;
signed int b = 1 << 8;  
signed int k = ~a & ~b;

有帮助吗?

I got stuck with the following Python code

>>> a = 0xff
>>> b = 1 << 8
>>> ~a & ~b
-512

Why is it -512? In binary notation it should look like this:

     a   0 1111 1111   -> 255
     b  01 0000 0000   -> 256

    ~a   1 0000 0000   -> -256
    ~b  10 1111 1111   -> -257

  ~a&~b 00 0000 0000   -> 0

I expected 0 as with signed int in C:

signed int a = 0xff;
signed int b = 1 << 8;  
signed int k = ~a & ~b;

Any help?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

庆幸我还是我 2024-10-06 16:34:06

为方便起见,假设 16 位整数(原则对于 32 位或 64 位没有改变):

a  = 0xff = 0000 0000 1111 1111
~a = -256 = 1111 1111 0000 0000

b  = 1<<8 = 0000 0001 0000 0000
~b = -257 = 1111 1110 1111 1111

-256 = 1111 1111 0000 0000
-257 = 1111 1110 1111 1111
--------------------------  &
-512 = 1111 1110 0000 0000

Assuming 16-bit integers for convenience (the principle doesn't change for 32 or 64 bit):

a  = 0xff = 0000 0000 1111 1111
~a = -256 = 1111 1111 0000 0000

b  = 1<<8 = 0000 0001 0000 0000
~b = -257 = 1111 1110 1111 1111

-256 = 1111 1111 0000 0000
-257 = 1111 1110 1111 1111
--------------------------  &
-512 = 1111 1110 0000 0000
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文