這篇“python變量賦值機制實例分析”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“python變量賦值機制實例分析”文章吧。
先說結論:
變量賦值屬于淺拷貝(關于深拷貝和淺拷貝的區別可以自己了解下)。故如果是可變類型變量(如a是list類型,a=b)賦值,修改a會牽連到b;如果是不可變類型(如int)的賦值,則修改任意變量不會傳遞。
可以看出,對于可變類型賦值,變量始終指向同一塊地址。
對于不可變類型變量的賦值,剛開始是指向同一塊地址,但修改任意變量,則修改的變量指向另外一塊地址,不會影響另外一個變量。
那么問題來了,對于自定義的類型進行變量賦值,屬于哪一種呢?
可以看出,對自定義變量中的屬性進行修改也會傳遞。
但是,如果對整體變量重新賦值呢?
可以看出,如果對整體變量重新賦值,修改不會傳遞,修改的變量會指向新的地址。
對于自定義變量賦值的區別,不留意很容易踩坑,如下面函數,將列表轉化為鏈表:
創建head
結點的副本cur,對其進行賦值,賦值后再讓它指向下一個節點,最終返回頭結點,但結果出人意料。仔細分析發現,在for循環中重新對cur賦值,cur = Node(i)
,使得cur不再指向head節點,而是指向另一塊內存地址,此時head
和cur
分路揚鑣,再也沒有關系了。
正確的做法是:
在for循環內,不對cur本身進行更改,只對其屬性next進行更改,這樣cur和head始終指向同一塊地址,最終return head.next
(因為第一個node沒數據,真正的node從head.next開始)
以上就是關于“python變量賦值機制實例分析”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。