如何动态覆盖__setitem__?(没有子类)

cam*_*ddc 4 python overriding built-in python-2.7

我无法在Python2.7中覆盖一些内置函数,例如'__setitem__' (尽管在我测试的先前版本中也是如此)

虽然我知道通过子类化很容易做到,但这不是我想要的,我需要能够动态覆盖这些方法.

显然,当我的类是' object ' 的子类时,重写的方法总是最终调用原始的方法,但是当我的类不是' 对象 '时,它的工作原理是:

>>> def new_implementation(k, v):
...     print 'New implementation'
...

### class that extends object
>>> class ExtendsObject(object):
...     def __setitem__(self, k, v):
...             print 'ExtendsObject implementation'
...



### Checking implementation
>>> obj = ExtendsObject()
>>> obj[0]=0
ExtendsObject implementation

### trying to override setitem, no success
>>> obj.__setitem__ = new_implementation
>>> obj[0]=0
ExtendsObject implementation




### class that does NOT extends object
>>> class DoesNotExtend:
...     def __setitem__(self, k, v):
...             print 'DoesNotExtend implementation'
...

### Checking implementation
>>> obj_2 = DoesNotExtend()
>>> obj_2[0]=0
DoesNotExtend implementation

### overriding now works!
>>> obj_2.__setitem__ = new_implementation
>>> obj_2[0]=0
New implementation
Run Code Online (Sandbox Code Playgroud)

出于某种原因,对象似乎对这些内置函数使用了一些不同的方法解析顺序.

这是一个错误吗?难道我做错了什么?

Sve*_*ach 5

对于旧式类,每次需要时都会在实例上查找特殊方法.新样式类只查找实例类型的特殊方法,而不是实例的字典本身 - 这就是为什么你看到你看到的行为.

(如果您不知道 - 新样式类是直接或间接派生自的类object.)