我正在嘗試修改第三方dict類以使其在某個時間點后不可變。對于大多數(shù)類,我可以分配給方法槽來修改行為。但是,這似乎不適用于所有類中的所有方法。特別是對于dict,我可以重新分配update,但不能__setitem__。為什么?它們有何不同?例如:class Freezable(object): def _not_modifiable(self, *args, **kw): raise NotImplementedError() def freeze(self): """ Disallow mutating methods from now on. """ print "FREEZE" self.__setitem__ = self._not_modifiable self.update = self._not_modifiable # ... others return selfclass MyDict(dict, Freezable): passd = MyDict()d.freeze()print d.__setitem__ # <bound method MyDict._not_modifiable of {}>d[2] = 3 # no error -- this is incorrect.d.update({4:5}) # raise NotImplementedError
1 回答

人到中年有點甜
TA貢獻1895條經(jīng)驗 獲得超7個贊
請注意,您可以定義class __setitem__,例如:
def __setitem__(self, key, value):
if self.update is Freezable._not_modifiable:
raise TypeError('{} has been frozen'.format(id(self)))
dict.__setitem__(self, key, value)
(這個方法有點笨拙;還有其他選擇。但即使 Python__setitem__直接調(diào)用類,它也是一種使它工作的方法。)
添加回答
舉報
0/150
提交
取消