Дескрипторы и предоставленные Python атрибуты
Я изучаю Python и пытаюсь лучше понять дескрипторы. Когда я смотрю на эту онлайн-книгу по Python: http://www.cafepy.com/article/python_attributes_and_methods/ch01s05.html, она говорит:
- Если attrname является специальным (то есть предоставленным Python) атрибутом для имени объекта, верните его.
Я не понимаю, что означает Python. Может кто-нибудь дать мне пример такого атрибута, предоставленного Python, который будет иметь приоритет над обычным порядком разрешения?
Примечание: меня интересуют только классы нового стиля (насколько я знаю, дескрипторы даже не применяются к старому стилю).
2 ответа
Как вы уже догадались, шаг 1 совершенно неправильный и не существует.
__class__
, например:
>>> class Test(object):
__dict__ = {'__class__' : "dict of Test"}
def __init__(self):
self.__dict__['__class__'] = "dict of test"
>>> test = Test()
>>> test.__class__
<class '__main__.Test'>
>>> test.__dict__
{'__class__': 'dict of test'}
>>> Test.__dict__
dict_proxy({'__dict__': {'__class__': 'dict of test'}, '__module__': '__main__', '__weakref__': <attribute '__weakref__' of 'Test' objects>, '__doc__': None, '__init__': <function __init__ at 0x02BD2770>})
>>>
эквивалент в классах старого стиля:
>>> class Test:
pass
>>> Test.__dict__["__class__"] = "spam"
>>> test = Test()
>>> test.__class__
<class __main__.Test at 0x02BD1110>
>>> test.__dict__ = {'__class__': "foo"}
>>> test.__class__
<class __main__.Test at 0x02BD1110>
в то время как
>>> test.__dict__ = {'__lolcat__': "bar"}
>>> test.__lolcat__
'bar'
Есть много других специальных имен атрибутов, в зависимости от типа объекта. Например, функции:
>>> def test():pass
>>> dir(test)
['__call__', '__class__', '__closure__', '__code__', '__defaults__', '__delattr__', '__dict__', '__doc__', '__format__', '__get__', '__getattribute__', '__globals__', '__hash__', '__init__', '__module__', '__name__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'func_closure', 'func_code', 'func_defaults', 'func_dict', 'func_doc', 'func_globals', 'func_name']
>>> test.func_closure
>>> test.__dict__['func_closure']='roflcopter'
>>> test.func_closure
>>> test.__dict__['foo']='bar'
>>> test.foo
'bar'
см. http://docs.python.org/reference/datamodel.html для обзора