亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

為什么 sys.maxint == "7ffffffffffffffff"?

為什么 sys.maxint == "7ffffffffffffffff"?

慕工程0101907 2022-01-11 20:11:36
>>> import sys>>> print '{0:64b}'.format(sys.maxint) 111111111111111111111111111111111111111111111111111111111111111>>> print '{0:16x}'.format(sys.maxint)7fffffffffffffff什么?7 是從哪里來的?這也不符合我對 2 的補碼的理解。
查看完整描述

3 回答

?
富國滬深

TA貢獻1790條經驗 獲得超9個贊

計算二進制表示中 1 的數量。其中有 63 個。讓我們寫入 64 位,這樣我們就可以看到前導 0:


0111111111111111111111111111111111111111111111111111111111111111

這是最大的 64 位整數:63 個 1 位,第 64 位為 0。如果最左邊的位是 1,我們將有-1. 哦親愛的!當符號位為 1 時,我們得到負數。那不好。64 個 1 實在太多了。


以上,4人一組:


0111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111

并以十六進制表示:


0111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111

7    f    f    f    f    f    f    f    f    f    f    f    f    f    f    f


查看完整回答
反對 回復 2022-01-11
?
慕的地8271018

TA貢獻1796條經驗 獲得超4個贊

在 2 的補碼中,可以用N位表示的最高正數0后跟N-1 1's。將所有N位設置為1產生 的表示-1。

所以在 64 位系統上,最大整數是 63 個 1 位。以十六進制表示,7后跟 7 f。


查看完整回答
反對 回復 2022-01-11
?
慕田峪7331174

TA貢獻1828條經驗 獲得超13個贊

在 64 位表示中,可以表示的最高數是2^63-1,


>>> import sys

>>> sys.maxint

9223372036854775807

>>> hex(9223372036854775807)

'0x7fffffffffffffff'

>>> (2**63)-1

9223372036854775807L

它適用于任何 N 位表示。例如對于 8 位,最大值為2^7-1


>>> hex(127)

'0x7f'

>>> hex(128)

'0x80'


查看完整回答
反對 回復 2022-01-11
  • 3 回答
  • 0 關注
  • 240 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號