色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

詳解python的內存分配機制

瀏覽:11日期:2022-06-20 10:28:22
開始

作為一個實例,讓我們創建四個變量并為其賦值:

variable1 = 1variable2 = 'abc'variable3 = (1,2)variable4 = [’a’,1]#打印他們的idsprint(’Variable1: ’, id(variable1))print(’Variable2: ’, id(variable2))print(’Variable3: ’, id(variable3))print(’Variable4: ’, id(variable4))

打印結果如下所示:

變量1:1747938368變量2:152386423976變量3:152382712136變量4:152382633160

每個變量都被分配了一個新的內存地址(以整數形式表示)。第一個假設是,每當我們使用“ =”給變量賦值時,Python都會創建一個新的內存地址來存儲變量。這是100%正確的嗎?當然不是!

我將創建兩個新變量(5和6)并使用現有變量的值給它們賦值。

variable5 = variable1variable6 = variable4print(’Variable1: ’, id(variable1))print(’Variable4: ’, id(variable4))print(’Variable5: ’, id(variable5))print(’Variable6: ’, id(variable6))

Python打印結果:

變量1:1747938368變量4:819035469000變量5:1747938368變量6:819035469000

你注意到,Python并未為這兩個變量創建新的內存地址嗎?這次,它只是把兩個新變量都指向了現有變量相同的存儲位置。

現在讓我們為變量1設置一個新值。注意:整數是不可變數據類型。

print(’Variable1: ’, id(variable1))variable1 = 2print(’Variable1: ’, id(variable1))

這將打印:

Variable1: 1747938368Variable1: 1747938400

這意味著每當我們使用=并將新值給現有變量賦值時,就會在內部創建一個新的內存地址來存儲該變量。讓我們看看它是否成立!

當值是可變數據類型時會發生什么?variable6是一個列表,讓我們在列表結尾append一個值并打印其內存地址:

print(’Variable6:’,id(variable6))variable6.append(’new’)print(’Variable6:’,id(variable6))

請注意,變量的內存地址保持不變,因為它是可變數據類型,我們僅更新了其元素。

Variable6:678181106888Variable6:678181106888

讓我們創建一個函數并將一個變量傳遞給它。如果我們在函數內部設置變量的值,它會發生什么?讓我們評估一下。

def update_variable(variable_to_update): print(id(variable_to_update))update_variable(variable6)print(’Variable6: ’, id(variable6))

請注意,variable_to_update的ID指向變量6的ID。

這意味著如果我們在函數中更新variable_to_update且variable_to_update是可變數據類型,那么variable6的值將更新。我們看一個具體例子:

variable6 = [’new’]print(’Variable6: ’, variable6)def update_variable(variable_to_update): variable_to_update.append(’inside’)update_variable(variable6)print(’Variable6: ’, variable6)

這將打印:

Variable6:[’new’]Variable6:[’new’,’inside’]

它向我們展示了如何在函數中的更新一個可變的變量,你可以看到函數類和函數外的可變變量都具有相同的ID。

如果我們在函數內給變量賦一個新值(而不是更新),無論它是不可變的還是可變的數據類型,那么一旦退出函數,更改將丟失:

print(’Variable6: ’, variable6)def update_variable(variable_to_update): print(id(variable_to_update)) variable_to_update = [’inside’]update_variable(variable6)print(’Variable6: ’, variable6)

Variable6:[’new’]344115201992Variable6:[’new’]

現在是一個有趣的場景:Python并不總是為所有新變量創建一個新的內存地址。

最后,如果我們為兩個不同的變量分配一個字符串值,例如“ a”,該怎么辦?它會創建兩個內存地址嗎?

variable_nine ='a'variable_ten ='a'print(’Variable9:’,id(variable_nine))print(’Variable10:’,id(variable_ten))

注意,這兩個變量具有相同的內存位置:

Variable9:792473698064Variable10:792473698064

如果我們創建兩個不同的變量并為其分配一個長字符串值,該怎么辦:

variable_nine = 'a' * 21variable_ten = 'a' * 21print(’Variable9: ’, id(variable_nine))print(’Variable10: ’, id(variable_ten))

這次Python為兩個變量創建了兩個不同內存位置:

Variable9:541949933872Variable10:541949933944

為什么? 這是因為Python啟動時會創建一個內部值緩存,這樣做是為了提供更快的結果。Python會為少量整數(如-5到256之間)和較小的字符串值分配了少量的內存地址。這就是我們示例中的短字符串都具有相同ID的原因,而長字符串的ID則不同。

== vs是

有時我們想檢查兩個對象是否相等。

如果我們使用==,它將檢查兩個參數是否包含相同的數據 如果我們使用is,那么Python將檢查兩個對象是否引用相同的對象,此時兩個對象的id必須相同

var1 = 'a' * 30 var2 = 'a' * 30 print(’var1:’,id(var1))#318966315648 print(’var2:’,id(var2))#168966317364 print(’==:’, var1 == var2)#返回True print(’is:’,var1 is var2)#返回False

以上就是詳解python的內存分配機制的詳細內容,更多關于python 內存分配機制的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲一区二区三区中文字幕 | 成人91在线 | 久久国产三级精品 | 男女男精品视频免费观看 | 久草视频福利资源站 | 欧美特黄高清免费观看的 | 自拍偷拍图区 | 中文字幕日韩欧美一区二区三区 | 中文字幕一区二区三 | 黄色三级视频网站 | 国产一区中文字幕在线观看 | 国产一区二区三区欧美精品 | 久操精品视频 | 国产乱弄视频在线观看 | 亚洲日产综合欧美一区二区 | 永久精品免费影院在线观看网站 | 中文一区 | 欧美精品久久久亚洲 | 日韩一级视频在线观看播放 | 成人毛片1024你懂的 | 国产a网站| 亚洲热播| 精品一区二区三区高清免费不卡 | 亚洲国产欧美精品一区二区三区 | 美女大片高清特黄a大片 | 久久久久久久久久综合情日本 | 日本精品视频一区二区三区 | 国产成人综合网在线观看 | 九草在线播放 | 最新步兵社区在线观看 | 写真片福利视频在线播放 | 亚洲免费在线观看视频 | 欧美视频三区 | 亚洲一级毛片免费在线观看 | 亚洲精品日本 | 久久综合给合久久狠狠狠97色69 | 国产在线播放成人免费 | 成人国产免费 | 国产精品1区 2区 3区 | 精品动漫一区二区 | 超薄肉色丝袜精品足j福利 超级乱淫视频aⅴ播放视频 |