简单的回答是:没有办法向绑定方法添加自定义属性.
答案很长.
Python中有function objects和method objects.定义类时,def
语句会创建一个function object,它位于类的命名空间中:
>>> class c:
... def m(self):
... pass
...
>>> c.m
<function m at 0x025FAE88>
函数对象有一个特殊的__dict__
属性,可以保存用户定义的属性:
>>> c.m.i = 0
>>> c.m.__dict__
{'i': 0}
方法对象是不同的野兽.它们是微小的对象,只包含对相应函数对象(__func__
)的引用和对其宿主对象(__self__
)的引用:
>>> c().m
<bound method c.m of <__main__.c object at 0x025206D0>>
>>> c().m.__self__
<__main__.c object at 0x02625070>
>>> c().m.__func__
<function m at 0x025FAE88>
>>> c().m.__func__ is c.m
True
方法对象提供了一个特殊的__getattr__
,用于将属性访问转发到函数对象:
>>> c().m.i
0
这也适用于__dict__
房产:
>>> c().m.__dict__['a'] = 42
>>> c.m.a
42
>>> c().m.__dict__ is c.m.__dict__
True
不过,设置属性遵循默认规则,而且由于属性没有自己的__dict__
,因此无法设置任意属性.
这类似于定义__slots__
和no __dict__
插槽的用户定义类,当try 设置不存在的插槽时,会引发AttributeError
(有关更多信息,请参阅docs on __slots__
):
>>> class c:
... __slots__ = ('a', 'b')
...
>>> x = c()
>>> x.a = 1
>>> x.b = 2
>>> x.c = 3
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'c' object has no attribute 'c'