Python?中的?list、tuple、set、dict的底層實(shí)現(xiàn)小結(jié)
在 Python 中,list、tuple、set 和 dict 是四種非常常用的數(shù)據(jù)結(jié)構(gòu)。它們的底層實(shí)現(xiàn)各有特點(diǎn),這些實(shí)現(xiàn)方式?jīng)Q定了它們的性能和使用場景。以下是對這四種數(shù)據(jù)結(jié)構(gòu)底層實(shí)現(xiàn)的詳細(xì)解釋:
1. list(列表)
list 是 Python 中最常用的數(shù)據(jù)結(jié)構(gòu)之一,它是一個(gè) 動態(tài)數(shù)組,用于存儲有序的元素集合。
底層實(shí)現(xiàn)
- 存儲方式:
list是一個(gè) 連續(xù)的內(nèi)存塊,用于存儲元素的引用(指針)。這意味著list中的元素可以是任意類型,因?yàn)榇鎯Φ氖菍ο蟮囊茫皇菍ο蟊旧怼?/li> - 動態(tài)擴(kuò)展:
list的大小是動態(tài)的。當(dāng)列表空間不足時(shí),Python 會分配一個(gè)新的更大的內(nèi)存塊,并將舊數(shù)據(jù)復(fù)制到新內(nèi)存塊中。通常,新的內(nèi)存塊大小是當(dāng)前大小的 1.125 倍(具體倍數(shù)可能因 Python 版本而異)。 - 內(nèi)存管理:由于
list是連續(xù)內(nèi)存,因此它支持快速的隨機(jī)訪問(通過索引訪問元素的時(shí)間復(fù)雜度為 O(1))。但插入和刪除操作(尤其是非尾部操作)可能需要移動大量元素,時(shí)間復(fù)雜度為 O(n)。
性能特點(diǎn)
優(yōu)點(diǎn):
- 支持快速的隨機(jī)訪問(通過索引)。
- 內(nèi)部實(shí)現(xiàn)簡單,適合存儲有序數(shù)據(jù)。
缺點(diǎn):
- 插入和刪除操作(尤其是非尾部操作)效率較低。
- 內(nèi)存占用可能較高,因?yàn)樾枰A(yù)留額外空間以支持動態(tài)擴(kuò)展。
2. tuple(元組)
tuple 是一個(gè) 不可變的有序集合,用于存儲一組固定的數(shù)據(jù)。
底層實(shí)現(xiàn)
- 存儲方式:與
list類似,tuple也是通過 連續(xù)的內(nèi)存塊 存儲元素的引用。不同的是,tuple是不可變的,這意味著它的大小和內(nèi)容在創(chuàng)建后不能被修改。 - 內(nèi)存分配:由于
tuple是不可變的,Python 在創(chuàng)建tuple時(shí)會一次性分配足夠的內(nèi)存來存儲所有元素,而不需要考慮動態(tài)擴(kuò)展。 - 性能優(yōu)化:由于不可變性,
tuple在某些情況下比list更高效,尤其是在作為字典的鍵或集合的元素時(shí),因?yàn)樗鼈兊墓V凳枪潭ǖ摹?/li>
性能特點(diǎn)
優(yōu)點(diǎn):
- 不可變性保證了數(shù)據(jù)的安全性。
- 在某些場景下(如作為哈希表的鍵)比
list更高效。
缺點(diǎn):
- 不支持動態(tài)修改,靈活性較差。
3. set(集合)
set 是一個(gè) 無序的集合,用于存儲唯一的元素。它支持高效的成員查找、插入和刪除操作。
底層實(shí)現(xiàn)
- 存儲方式:
set的底層實(shí)現(xiàn)是基于 哈希表 的。每個(gè)元素通過哈希函數(shù)映射到一個(gè)唯一的哈希值,并存儲在哈希表中。 - 沖突解決:當(dāng)兩個(gè)元素的哈希值沖突時(shí),Python 使用 鏈表 或 開放尋址法 來解決沖突。具體實(shí)現(xiàn)取決于 Python 的版本。
- 動態(tài)擴(kuò)展:與
list類似,set的大小也是動態(tài)的。當(dāng)哈希表的負(fù)載因子(元素?cái)?shù)量與哈希表大小的比值)超過某個(gè)閾值時(shí),哈希表會自動擴(kuò)展,重新分配更大的內(nèi)存空間并重新哈希所有元素。
性能特點(diǎn)
優(yōu)點(diǎn):
- 成員查找、插入和刪除操作的時(shí)間復(fù)雜度為 O(1)。
- 自動去重,適合存儲唯一元素。
缺點(diǎn):
- 不支持重復(fù)元素。
- 不支持有序訪問。
4. dict(字典)
dict 是一個(gè) 鍵值對的集合,用于存儲映射關(guān)系。它是 Python 中最強(qiáng)大的數(shù)據(jù)結(jié)構(gòu)之一。
底層實(shí)現(xiàn)
- 存儲方式:
dict的底層實(shí)現(xiàn)也是基于 哈希表 的。每個(gè)鍵通過哈希函數(shù)映射到一個(gè)唯一的哈希值,并存儲在哈希表中。值則與鍵關(guān)聯(lián)存儲。 - 沖突解決:與
set類似,dict也使用鏈表或開放尋址法解決哈希沖突。 - 動態(tài)擴(kuò)展:當(dāng)哈希表的負(fù)載因子超過某個(gè)閾值時(shí),
dict會自動擴(kuò)展,重新分配更大的內(nèi)存空間并重新哈希所有鍵值對。 - 鍵的唯一性:
dict的鍵必須是不可變類型(如整數(shù)、字符串、元組等),因?yàn)樗鼈冃枰С止2僮鳌?/li>
性能特點(diǎn)
優(yōu)點(diǎn):
- 鍵值對查找、插入和刪除操作的時(shí)間復(fù)雜度為 O(1)。
- 支持靈活的鍵值映射關(guān)系。
缺點(diǎn):
- 鍵必須是不可變類型。
- 不支持有序訪問(Python 3.7+ 中的
dict保持了插入順序,但這不是通過哈希表實(shí)現(xiàn)的,而是通過額外的機(jī)制)。
總結(jié)
| 數(shù)據(jù)結(jié)構(gòu) | 底層實(shí)現(xiàn) | 優(yōu)點(diǎn) | 缺點(diǎn) |
|---|---|---|---|
list | 動態(tài)數(shù)組 | 隨機(jī)訪問快,支持動態(tài)擴(kuò)展 | 插入和刪除效率低,內(nèi)存占用可能較高 |
tuple | 靜態(tài)數(shù)組 | 不可變,適合哈希 | 不支持動態(tài)修改 |
set | 哈希表 | 成員查找、插入和刪除快,自動去重 | 不支持重復(fù)元素,不支持有序訪問 |
dict | 哈希表 | 鍵值對查找、插入和刪除快 | 鍵必須是不可變類型,不支持有序訪問 |
擴(kuò)展閱讀
- Python 官方文檔:數(shù)據(jù)模型
- Python 源碼分析:可以參考 Python 源碼 中的實(shí)現(xiàn)細(xì)節(jié),特別是
listobject.c、tupleobject.c、setobject.c和dictobject.c文件。 - 性能優(yōu)化:了解這些數(shù)據(jù)結(jié)構(gòu)的底層實(shí)現(xiàn)可以幫助你更好地選擇合適的數(shù)據(jù)結(jié)構(gòu)來優(yōu)化代碼性能。
如果你對某個(gè)數(shù)據(jù)結(jié)構(gòu)的底層實(shí)現(xiàn)有更具體的問題,歡迎繼續(xù)提問!
到此這篇關(guān)于Python 中的 list、tuple、set、dict的底層實(shí)現(xiàn)的理解的文章就介紹到這了,更多相關(guān)Python list、tuple、set、dict內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Opencv實(shí)現(xiàn)計(jì)算兩條直線或線段角度方法詳解
這篇文章主要介紹了Opencv實(shí)現(xiàn)計(jì)算兩條直線或線段角度方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12
python中使用PIL制作并驗(yàn)證圖片驗(yàn)證碼
本篇文章給大家分享了python中使用PIL制作并驗(yàn)證圖片驗(yàn)證碼的具體代碼以及說明,需要的朋友參考下吧。2018-03-03
python中實(shí)現(xiàn)迭代器(iterator)的方法示例
我們經(jīng)常需要遍歷一個(gè)對象中的元素,在Python中這種功能是通過迭代器來實(shí)現(xiàn)的。下面這篇文章主要給大家介紹了python中實(shí)現(xiàn)迭代器(iterator)的方法示例,需要的朋友可以參考借鑒,下面來一起看看吧。2017-01-01
python結(jié)合selenium獲取XX省交通違章數(shù)據(jù)的實(shí)現(xiàn)思路及代碼
這篇文章主要介紹了python結(jié)合selenium獲取XX省交通違章數(shù)據(jù)的實(shí)現(xiàn)思路及代碼方法的相關(guān)資料2016-06-06
采用python實(shí)現(xiàn)簡單QQ單用戶機(jī)器人的方法
這篇文章主要介紹了采用python實(shí)現(xiàn)簡單QQ單用戶機(jī)器人的方法,需要的朋友可以參考下2014-07-07
python 文件下載之?dāng)帱c(diǎn)續(xù)傳的實(shí)現(xiàn)
用python進(jìn)行文件下載的時(shí)候,一旦出現(xiàn)網(wǎng)絡(luò)波動問題,導(dǎo)致文件下載到一半。如果將下載不完全的文件刪掉,那么又需要從頭開始,如果連續(xù)網(wǎng)絡(luò)波動,是不是要頭禿了。本文提供斷點(diǎn)續(xù)傳下載工具方法,希望可以幫助到你2021-11-11
Python制作簡易聊天器,搭建UDP網(wǎng)絡(luò)通信模型
這篇文章主要介紹了Python制作簡易聊天器,搭建UDP網(wǎng)絡(luò)通信模型,用UDP建立網(wǎng)絡(luò)模型來完成一個(gè)簡單的聊天器,感興趣的小伙伴可以參考一下,希望對你有所幫助2022-01-01

