欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2019年01月24日 09:03:16   作者:Devin01213  
今天小編就為大家分享一篇關(guān)于Python字典的核心底層原理講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

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

存儲數(shù)據(jù)的過程

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

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

1、計算name的散列值。

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

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

獲取數(shù)據(jù)的過程

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

1、計算name的散列值

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

小結(jié):

1.鍵必須可散列,如數(shù)字、元組、字符串;自定義對象需要滿足支持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. 字典在內(nèi)存中開銷巨大,典型的空間換時間;

3. 鍵查詢速度很快;

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • Python list與NumPy array 區(qū)分詳解

    Python list與NumPy array 區(qū)分詳解

    這篇文章主要介紹了Python list與NumPy array 區(qū)分詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Python使用requests模塊發(fā)送http請求的方法介紹

    Python使用requests模塊發(fā)送http請求的方法介紹

    Python?Requests是一個?HTTP?庫,它允許我們向?Web?服務(wù)器發(fā)送??HTTP?請求,并獲取響應(yīng)結(jié)果,本文將會詳細(xì)介紹Python?requests模塊如何發(fā)送http請求,文中有相關(guān)的代碼示例,需要的朋友可以參考下
    2023-06-06
  • 快速解釋如何使用pandas的inplace參數(shù)的使用

    快速解釋如何使用pandas的inplace參數(shù)的使用

    這篇文章主要介紹了快速解釋如何使用pandas的inplace參數(shù)的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Python機(jī)器學(xué)習(xí)入門(二)之Python數(shù)據(jù)理解

    Python機(jī)器學(xué)習(xí)入門(二)之Python數(shù)據(jù)理解

    這篇文章主要介紹了Python機(jī)器學(xué)習(xí)入門知識,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • python中ThreadPoolExecutor線程池和ProcessPoolExecutor進(jìn)程池

    python中ThreadPoolExecutor線程池和ProcessPoolExecutor進(jìn)程池

    這篇文章主要介紹了python中ThreadPoolExecutor線程池和ProcessPoolExecutor進(jìn)程池,文章圍繞主題相關(guān)資料展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-06-06
  • 淺析Python中全局變量和局部變量的使用

    淺析Python中全局變量和局部變量的使用

    一個變量的名稱除了可以代表不同的東西以外,也表示“哪里可以使用”這個變量,這篇文章將會介紹全局變量和局部變量的用法和差異,感興趣的可以了解下
    2021-06-06
  • 用python實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)

    用python實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了用python實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Python+OpenCV圖片局部區(qū)域像素值處理詳解

    Python+OpenCV圖片局部區(qū)域像素值處理詳解

    這篇文章主要為大家詳細(xì)介紹了Python+OpenCV圖片局部區(qū)域像素值處理,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 在centos7中分布式部署pyspider

    在centos7中分布式部署pyspider

    PySpider:一個國人編寫的強(qiáng)大的網(wǎng)絡(luò)爬蟲系統(tǒng)并帶有強(qiáng)大的WebUI。采用Python語言編寫,分布式架構(gòu),支持多種數(shù)據(jù)庫后端,強(qiáng)大的WebUI支持腳本編輯器,任務(wù)監(jiān)視器,項(xiàng)目管理器以及結(jié)果查看器。
    2017-05-05
  • Python+Mysql實(shí)現(xiàn)登錄注冊完整代碼示例

    Python+Mysql實(shí)現(xiàn)登錄注冊完整代碼示例

    在開發(fā)中用戶注冊和登錄是常見的功能需求,這篇文章主要給大家介紹了關(guān)于Python+Mysql實(shí)現(xiàn)登錄注冊的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03

最新評論