91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python字典的核心底層原理講解

發布時間:2020-10-05 11:38:21 來源:腳本之家 閱讀:158 作者:Devin01213 欄目:開發技術

字典對象的核心是散列表。散列表是一個稀疏數組(總是有空白元素的數組),數組的每個單元叫做 bucket。每個 bucket 有兩部分:一個是鍵對象的引用,一個是值對象的引用。所有 bucket 結構和大小一致,我們可以通過偏移量來讀取指定 bucket。下面通過存儲與獲取數據的過程介紹字典的底層原理。

Python字典的核心底層原理講解

存儲數據的過程

例如,我們將‘name' = ‘張三' 這個鍵值對存儲到字典map中,假設數組長度為8,可以用3位二進制表示。

>>> map = {}
>>> map
{}
>>> map['name'] = '張三'

1、計算name的散列值。

>>> bin(hash('name'))
'0b101011100000110111101000101010100010011010110010100101001000110'

2、用散列值的最右邊 3 位數字作為偏移量,即“110”,十進制是數字 6。我們查看偏移量 6,對應的 bucket 是否為空。如果為空,則將鍵值對放進去。如果不為空,則依次取右移 3 位作為偏移量,即“000”,十進制是數字0,循環此過程,直到找到為空的 bucket 將鍵值對放進去。python 會根據散列表的擁擠程度擴容。“擴容”指的是:創造更大的數組,將原有內容拷貝到新數組中。接近 2/3 時,數組就會擴容。擴容后,偏移量的數字個數增加,如數組長度擴容到16時,可以用最右邊4位數字作為偏移量。

Python字典的核心底層原理講解

獲取數據的過程

>>> map.get('name')
'張三'

1、計算name的散列值

2、用最右邊 3 位數字作為偏移量,即“110”,十進制是數字6。查看偏移量 6,對應的 bucket 是否為空。如果為空,則返回 None。如果不為空,則將這個 bucket 的鍵對象計算對應散列值,和我們的散列值進行比較,如果相等,則將對應“值對象”返回;如果不相等,則再依次取其他幾位數字,重新計算偏移量。循環此過程。

小結:

1.鍵必須可散列,如數字、元組、字符串;自定義對象需要滿足支持hash、支持通過__eq__()方法檢測相等性、若 a==b 為真,則 hash(a)==hash(b)也為真。

>>> b = [1,2] //List不可散列
>>> bin(hash(b))
Traceback (most recent call last):
 File "<pyshell#90>", line 1, in <module>
  bin(hash(b))
TypeError: unhashable type: 'list'

2. 字典在內存中開銷巨大,典型的空間換時間;

3. 鍵查詢速度很快;

4. 往字典里面添加新建可能導致擴容,導致散列表中鍵的次序變化。因此,不要在遍歷字典的同時進行字典的修改。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

辉县市| 长宁区| 额尔古纳市| 安平县| 玉树县| 象山县| 新宁县| 乌鲁木齐县| 格尔木市| 辽阳县| 电白县| 汨罗市| 呼和浩特市| 海门市| 开江县| 禄丰县| 湟中县| 永济市| 古交市| 彩票| 泽库县| 台东市| 黄骅市| 常州市| 吉林市| 搜索| 紫金县| 缙云县| 三门县| 华亭县| 闵行区| 新龙县| 临江市| 崇阳县| 姚安县| 安泽县| 肥城市| 楚雄市| 历史| 榆树市| 汝州市|