中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python中內存分配機制的示例分析

發布時間:2021-05-10 14:28:24 來源:億速云 閱讀:140 作者:小新 欄目:開發技術

這篇文章主要介紹了python中內存分配機制的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Python主要用來做什么

Python主要應用于:1、Web開發;2、數據科學研究;3、網絡爬蟲;4、嵌入式應用開發;5、游戲開發;6、桌面應用開發。

開始

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

variable1 = 1
variable2 = "abc"
variable3 = (1,2)
variable4 = ['a',1]

#打印他們的ids
print('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 = variable1
variable6 = variable4

print('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 = 2
print('Variable1: ', id(variable1))

這將打印:

Variable1: 1747938368
Variable1: 1747938400

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

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

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

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

Variable6:678181106888
Variable6: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']
344115201992
Variable6:['new']

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

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

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

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

Variable9:792473698064
Variable10:792473698064

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

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

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

Variable9:541949933872
Variable10: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中內存分配機制的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

辉南县| 新竹县| 德兴市| 长岭县| 太谷县| 神木县| 温泉县| 延吉市| 西宁市| 饶河县| 河曲县| 开平市| 唐山市| 衡山县| 德钦县| 常州市| 新野县| 阳西县| 阿瓦提县| 郑州市| 苍溪县| 靖远县| 巢湖市| 雷州市| 阳江市| 德阳市| 汉阴县| 八宿县| 绥阳县| 旌德县| 司法| 工布江达县| 吉安县| 成安县| 沙田区| 轮台县| 辰溪县| 英吉沙县| 永福县| 安图县| 镇雄县|