Python可變對象與不可變對象原理解析
一、原理
- 可變對象:list dict set
- 不可變對象:tuple string int float bool
1. python不允許程序員選擇采用傳值還是傳引用。Python參數(shù)傳遞采用的肯定是“傳對象引用”的方式。實際上,這種方式相當(dāng)于傳值和傳引用的一種綜合。如果函數(shù)收到的是一個可變對象的引用,就能修改對象的原始值——相當(dāng)于通過“傳引用”來傳遞對象。如果函數(shù)收到的是一個不可變對象的引用,就不能直接修改原始對象——相當(dāng)于通過“傳值'來傳遞對象。
2. 當(dāng)人們復(fù)制可變對象時,就復(fù)制了可變對象的引用,如果改變引用的值,則修改了原始的參數(shù)。
3. 為了簡化內(nèi)存管理,Python通過引用計數(shù)機制實現(xiàn)自動垃圾回收功能,Python中的每個對象都有一個引用計數(shù),用來計數(shù)該對象在不同場所分別被引用了多少次。每當(dāng)引用一次Python對象,相應(yīng)的引用計數(shù)就增1,每當(dāng)消毀一次Python對象,則相應(yīng)的引用就減1,只有當(dāng)引用計數(shù)為零時,才真正從內(nèi)存中刪除Python對象。
二、具體應(yīng)用
1. = 與 copy 與 deepcopy
= 賦值并不會新建對象,b 和 a 引用的是同一個對象。
copy 方法會新建對象,b 和 a 引用的是不同的對象,但里面的可變對象(列表 y)依然引用的是同一個對象。也就是說 copy 方法只會復(fù)制最外面一層,里面的不會新建對象而是直接用原對象,是淺層復(fù)制。
deepcopy 方法會新建對象,里面的可變對象也會新建對象。實際上deepcopy是遞歸copy,是深層復(fù)制。
代碼實例
# = 賦值 a = {'x': 11, 'y': [22, 33]} b = a print(id(a)) >>> 1630605400840 print(id(b)) >>> 1630605400840 # copy 方法 a = {'x': 11, 'y': [22, 33]} b = a.copy() print(id(a)) >>> 2357161715536 print(id(b)) >>> 2357161715608 print(id(a['y'])) >>> 140720772330640 print(id(b['y'])) >>> 140720772330640 # deepcopy 方法 import copy a = {'x': 11, 'y': [22, 33]} b = copy.deepcopy(a) print(id(a)) >>> 2357161715536 print(id(b)) >>> 2357161715608 print(id(a['x'])) >>> 140720772330640 print(id(b['x'])) >>> 140720772330640 print(id(a['y'])) >>> 2462852627784 print(id(b['y'])) >>> 2462852628232
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在Django中創(chuàng)建第一個靜態(tài)視圖
這篇文章主要介紹了在Django中創(chuàng)建第一個靜態(tài)視圖的方法,與其他編程語言的開始一樣,以Hello world作為示例,需要的朋友可以參考下2015-07-07python神經(jīng)網(wǎng)絡(luò)Keras構(gòu)建CNN網(wǎng)絡(luò)訓(xùn)練
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)學(xué)習(xí)使用Keras構(gòu)建CNN網(wǎng)絡(luò)訓(xùn)練,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05python優(yōu)化數(shù)據(jù)預(yù)處理方法Pandas pipe詳解
在本文中,我們將重點討論一個將多個預(yù)處理操作組織成單個操作的特定函數(shù):pipe。我將通過示例方式來展示如何使用它,讓我們從數(shù)據(jù)創(chuàng)建數(shù)據(jù)幀開始吧2021-11-11