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'。