對于下面的情況使用 acopy和 a方法有什么區別?defaultdictbase_data = {...}for item in iterable: # approach 1 <-- why wouldn't this work? data = defaultdict(lambda: base_data) # approach 2 data = deepcopy(base_data) ...看來第一種方法是錯誤的對象類型,但是有人可以澄清這兩種方法之間的區別以及為什么這不起作用嗎?
1 回答

牧羊人nacy
TA貢獻1862條經驗 獲得超7個贊
deepcopy
對原件進行全新的深度復制dict
;新副本與原始副本完全分離,因此對其中一個副本的后續修改根本不會影響另一個副本。defaultdict(lambda: base_data)
dict
每當對某個鍵的括號查找失敗時,都會插入帶有別名的值的鍵base_data
(因此修改任何值都會修改所有值,同樣的方式b = a
后跟對兩者進行變異操作或a
影響b
兩者)。defaultdict
的默認“構造函數”應該始終返回一個不可變類型(別名可以,因為它們不能改變)或一個全新的獨立可變類型(例如,對于base_data
不可變值,可以使用淺拷貝defaultdict(base_dict.copy)
;對于base_data
可變值,您可以d 需要一個深層副本來保持它們獨立,defaultdict(lambda: copy.deepcopy(base_data))
或者只是將定義的文字復制base_data
到 中lambda
(如果它足夠短)。
#1 有一個用例(制作一個完全獨立的副本,可以更新而不影響其他副本)。
#2,正如你所寫的,只是沒有;所有鍵之間共享的可變類型的許多別名本質上是無用的;您需要復制或全新構造來默認為可變值才能創建有用的defaultdict
.
添加回答
舉報
0/150
提交
取消