日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

python變量賦值機制踩坑記錄_python

作者:驚瑟 ? 更新時間: 2022-04-25 編程語言

先說結論:

變量賦值屬于淺拷貝(關于深拷貝和淺拷貝的區別可以自己了解下)。故如果是可變類型變量(如a是list類型,a=b)賦值,修改a會牽連到b;如果是不可變類型(如int)的賦值,則修改任意變量不會傳遞。

1. 可變類型賦值

可以看出,對于可變類型賦值,變量始終指向同一塊地址。

2. 不可變類型賦值

對于不可變類型變量的賦值,剛開始是指向同一塊地址,但修改任意變量,則修改的變量指向另外一塊地址,不會影響另外一個變量。

那么問題來了,對于自定義的類型進行變量賦值,屬于哪一種呢?

3. 自定義類型變量賦值

?可以看出,對自定義變量中的屬性進行修改也會傳遞。

但是,如果對整體變量重新賦值呢?

可以看出,如果對整體變量重新賦值,修改不會傳遞,修改的變量會指向新的地址。

對于自定義變量賦值的區別,不留意很容易踩坑,如下面函數,將列表轉化為鏈表:

創建head結點的副本cur,對其進行賦值,賦值后再讓它指向下一個節點,最終返回頭結點,但結果出人意料。仔細分析發現,在for循環中重新對cur賦值,cur = Node(i),使得cur不再指向head節點,而是指向另一塊內存地址,此時headcur分路揚鑣,再也沒有關系了。

正確的做法是:

在for循環內,不對cur本身進行更改,只對其屬性next進行更改,這樣cur和head始終指向同一塊地址,最終return head.next(因為第一個node沒數據,真正的node從head.next開始)?

原文鏈接:https://blog.csdn.net/qq_34062683/article/details/123029850

欄目分類
最近更新