在 Python 中,賦值運算子(例如 =)不會建立物件的副本。相反,它們引用記憶體中現有的物件。此行為可能會導致意想不到的後果,如以下程式碼所示:
dict_a = dict_b = dict_c = {} dict_c['hello'] = 'goodbye' print(dict_a) print(dict_b) print(dict_c)
預期輸出:
{} {} {'hello': 'goodbye'}
實際輸出:
{'hello': 'goodbye'} {'hello': 'goodbye'} {'hello': 'goodbye'}
在此例如,我們希望創建三個獨立的字典。然而,結果顯示 dict_a、dict_b 和 dict_c 都引用同一個字典物件。為 dict_c 分配鍵會修改共享字典,這會反映在所有三個變數中。
為了實現創建獨立副本的所需行為,Python 提供了幾個選項:
dict_a = {1: 2} dict_b = dict_a.copy() dict_b[3] = 4 print(dict_a) print(dict_b)
輸出:
{1: 2} {1: 2, 3: 4}
import copy dict_a = {1: 2, 'nested': {3: 4}} dict_b = copy.deepcopy(dict_a) dict_b['nested'][5] = 6 print(dict_a) print(dict_b)
輸出:
{1: 2, 'nested': {3: 4}} {1: 2, 'nested': {3: 4, 5: 6}}
透過使用這些方法,可以控制Python 中的物件分配並防止對共享對象的意外修改。
以上是Python 的物件分配如何運作以及如何建立獨立副本?的詳細內容。更多資訊請關注PHP中文網其他相關文章!