Дескрипторы и предоставленные Python атрибуты

Я изучаю Python и пытаюсь лучше понять дескрипторы. Когда я смотрю на эту онлайн-книгу по Python: http://www.cafepy.com/article/python_attributes_and_methods/ch01s05.html, она говорит:

  1. Если 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 для обзора

Другие вопросы по тегам