Python 變量的創(chuàng)建過程詳解
一、變量創(chuàng)建過程
首先,當我們定義了一個變量name = 'Kwan'的時候,在內(nèi)存中其實是做了這樣一件事:
程序開辟了一塊內(nèi)存空間,將'Kwan'存儲進去,再讓變量名name指向'Kwan'所在的內(nèi)存地址。如下圖所示:

我們可以通過id()方法查看這個變量在內(nèi)存中的地址。
name = 'Kwan' print(id(name))
二、變量的修改
一般我們認為修改一個變量就是用新值把就舊值覆蓋掉,可Python真是這么實現(xiàn)的么?
name = 'Kwan' print(id(name)) name = 'Kobe' print(id(name))

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

三、變量的指向關系
問:下面這段代碼為何出現(xiàn)這樣的現(xiàn)象?
name1 = 'Kwan' name2 = name1 print(name1, name2) name1 = 'Kobe' print(name1, name2)

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

從上面的示意圖中我們可以知道,當執(zhí)行name2 = name1時,事實上時讓name2指向了'Kwan'所在的內(nèi)存地址。
修改name1的值,相當于斷開了name1到'Kwan'的鏈接,重新建立name1和'Kobe'之間的鏈接。在這個過程中,始終沒有影響到name2和'Kwan'之間的關系,因此name2還是'Kwan',而name1變成了'Kobe'。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
python opencv實現(xiàn)目標區(qū)域裁剪功能
這篇文章主要介紹了python opencv實現(xiàn)目標區(qū)域裁剪功能,通過截取到坐標信息以后用CV2的裁剪就可以完美實現(xiàn),本文給大家分享實例代碼,需要的朋友可以參考下2021-07-07
Pandas之drop_duplicates:去除重復項方法
下面小編就為大家分享一篇Pandas之drop_duplicates:去除重復項方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04

