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

Python3.6 之后字典是有序的?

 更新時間:2021年12月10日 10:21:13   作者:somenzz Python七號  
字典數據是有序的, 但是這個序不是由外部控制, 而是內部字典定位機制的序 所以對外來講, 數據本身是無序的 你每次遍歷的順序一樣, 是因為枚舉結果是按內部排序輸出 而無序則表示在你無法從外部控制最終的輸出順序,下面我們來學習Python字典有序性的相關資料又當怎樣吧

字典的本質就是 hash 表,hash 表就是通過 key 找到其 value ,平均情況下你只需要花費 O(1) 的時間復雜度即可以完成對一個元素的查找,字典是否有序,并不是指字典能否按照鍵或者值進行排序,而是字典能否按照插入鍵值的順序輸出對應的鍵值。

比如,對于一個無序字典,插入順序和遍歷的順序是不一致的:

>>> my_dict = dict()
>>> my_dict["name"] = "lowman"
>>> my_dict["age"] = 26
>>> my_dict["girl"] = "Tailand"
>>> my_dict["money"] = 80
>>> my_dict["hourse"] = None
>>> for key,value in my_dict.items():
...     print(key,value)
...
money 80
girl Tailand
age 26
hourse None
name lowman


而一個有序字典的輸出是這樣的:

name lowman
age 26
girl Tailand
money 80
hourse None


那為什么 Python3.6 之后,Python 的字典就有序了呢?

先從 Python3.6 之前說起。在 Python 3.6 之前,其數據結構如下圖所示:

由于不同鍵的哈希值不一樣,哈希表(entries)中的順序是按照哈希值大小排序的,遍歷時從前往后遍歷并不能輸出鍵值插入的順序,其表現起來就是無序的。

此外,這種方式還有一個缺點,就是如果以稀疏的哈希表存儲時,會浪費較多的內存空間,Python3.6 之后,對其進行了優(yōu)化,哈希索引和真正的鍵值對分開存放,數據結構如下所示:

indices 指向了一列索引,entries 指向了原本的存儲哈希表內容的結構。

你可以把 indices 理解成新的簡化版的哈希表,entries 理解成一個數組,數組中的每個元素是原本應該存儲的哈希結果:鍵和值。

查找或者插入一個元素的時候,根據鍵的哈希值結果取模 indices 的長度,就能得到對應的數組下標,再根據對應的數組下標到 entries 中獲取到對應的結果,比如 hash("key2") % 8 的結果是 3,那么 indices[3] 的值是 1,這時候到 entries 中找到對應的 entries[1] 既為所求的結果:

這么做的好處是空間利用率得到了較大的提升,我們以 64 位操作系統為例,每個指針的長度為 8 字節(jié),則原本需要 8 * 3 * 8 為 192

現在變成了 8 * 3 * 3 + 1 * 8 為 80,節(jié)省了 58% 左右的內存空間,如下圖所示:

此外,由于 entries 是按照插入順序進行插入的數組,對字典進行遍歷時能按照插入順序進行遍歷,這也是為什么 Python3.6 以后的版本字典對象是有序的原因。

最后:

如果你對 Python 解釋器的實現感興趣,可以閱讀 CPython 的源碼,源碼之下無秘密,閱讀源碼也是提升自己最快的學習方式,這里推薦一個學習 CPython 的開源倉庫 CPython-Internals,圖文注釋并茂,是非常有價值的學習資源

到此這篇關于Python3.6 之后字典是有序的?的文章就介紹到這了,更多相關Python字典有序性內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Python讀取圖片的方法詳解

    Python讀取圖片的方法詳解

    這篇文章主要為大家詳細介紹了Python中讀取圖片的實現方法,文中的示例代碼簡潔易懂,具有一定的參考價值,需要的小伙伴可以跟隨小編一起學習一下
    2023-08-08
  • python內置函數:lambda、map、filter簡單介紹

    python內置函數:lambda、map、filter簡單介紹

    Python 內置了一些比較特殊且實用的函數,使用這些能使你的代碼簡潔而易讀。下面對python內置函數:lambda、map、filter簡單介紹下,需要的朋友參考下吧
    2017-11-11
  • 在VS2017中用C#調用python腳本的實現

    在VS2017中用C#調用python腳本的實現

    這篇文章主要介紹了在VS2017中用C#調用python腳本的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • python編寫猜數字小游戲

    python編寫猜數字小游戲

    這篇文章主要為大家詳細介紹了python編寫猜數字小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 淺談Python幾種常見的歸一化方法

    淺談Python幾種常見的歸一化方法

    這篇文章主要介紹了幾種常見的歸一化方法,數據歸一化是深度學習數據預處理中非常關鍵的步驟,可以起到統一量綱,防止小數據被吞噬的作用,需要的朋友可以參考下
    2023-04-04
  • flask中使用SQLAlchemy進行輔助開發(fā)的代碼

    flask中使用SQLAlchemy進行輔助開發(fā)的代碼

    在Web.py, Django, Flask, Tornado里,自帶的ORM功能比較缺乏,推薦大家使用SQLAlchemy來輔助開發(fā)
    2013-02-02
  • AI生成圖片Stable?Diffusion環(huán)境搭建與運行方法

    AI生成圖片Stable?Diffusion環(huán)境搭建與運行方法

    Stable?Diffusion是一種基于擴散過程的生成模型,由Ge?et?al.在2021年提出,該模型利用了隨機變量的穩(wěn)定分布,通過遞歸地應用擴散過程來生成高質量的圖像,這篇文章主要介紹了AI圖片生成Stable?Diffusion環(huán)境搭建與運行,需要的朋友可以參考下
    2023-05-05
  • python實現搜索指定目錄下文件及文件內搜索指定關鍵詞的方法

    python實現搜索指定目錄下文件及文件內搜索指定關鍵詞的方法

    這篇文章主要介紹了python實現搜索指定目錄下文件及文件內搜索指定關鍵詞的方法,可實現針對文件夾及文件內關鍵詞的搜索功能,需要的朋友可以參考下
    2015-06-06
  • Python讀取xlsx文件報錯:xlrd.biffh.XLRDError:?Excel?xlsx?file;not?supported問題解決

    Python讀取xlsx文件報錯:xlrd.biffh.XLRDError:?Excel?xlsx?file;no

    這篇文章主要給大家介紹了關于Python庫xlrd中的xlrd.open_workbook()函數讀取xlsx文件報錯:xlrd.biffh.XLRDError:?Excel?xlsx?file;not?supported問題解決的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • django加載本地html的方法

    django加載本地html的方法

    今天小編就為大家分享一篇django加載本地html的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05

最新評論