Python之變量的創建過程


Python之變量的創建過程

一、變量創建過程

首先,當我們定義了一個變量name = 'Kwan'的時候,在內存中其實是做了這樣一件事:

程序開辟了一塊內存空間,將'Kwan'存儲進去,再讓變量名name指向'Kwan'所在的內存地址。如下圖所示:

我們可以通過id()方法查看這個變量在內存中的地址。

name = 'Kwan'
print(id(name))

二、變量的修改

一般我們認為修改一個變量就是用新值把就舊值覆蓋掉,可Python真是這么實現的么?

name = 'Kwan'
print(id(name))
name = 'Kobe'
print(id(name))

實際的原理是什么樣的呢?程序先申請了一塊內存空間來存儲'Kwan',讓name變量名指向這塊內存空間,往下執行name = 'Kobe'之后,又申請了另一塊內存空間來存儲'Kobe',並讓原本指向'Kwan'內存的鏈接斷開,讓name再指向'Kobe'。

三、變量的指向關系

問:下面這段代碼為何出現這樣的現象?

name1 = 'Kwan'
name2 = name1
print(name1, name2)

name1 = 'Kobe'
print(name1, name2)

要想知道上面問題的結果是為什么,首先要了解再內存中兩個變量的存儲情況。

從上面的示意圖中我們可以知道,當執行name2 = name1時,事實上時讓name2指向了'Kwan'所在的內存地址。

修改name1的值,相當於斷開了name1到'Kwan'的鏈接,重新建立name1和'Kobe'之間的鏈接。在這個過程中,始終沒有影響到name2和'Kwan'之間的關系,因此name2還是'Kwan',而name1變成了'Kobe'。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM