Python descriptor How-Toは、記述子に関してproperty()
を実装する方法を記述しています。私は__get__
メソッドの最初のifブロックの理由を理解していません。どんな状況下でobj
はNone
になりますか?それから何が起こるはずですか? __get__
と__del__
の方法でそれをチェックしないのはなぜですか?プロパティ()の記述子プロトコルの実装
コードは少し長めですが、単なるスニペットではなく完全なコードを与える方がよいでしょう。疑わしい行がマークされています。 descriptor documentationから
class Property(object):
"Emulate PyProperty_Type() in Objects/descrobject.c"
def __init__(self, fget=None, fset=None, fdel=None, doc=None):
self.fget = fget
self.fset = fset
self.fdel = fdel
if doc is None and fget is not None:
doc = fget.__doc__
self.__doc__ = doc
def __get__(self, obj, objtype=None):
# =====>>> What's the reason of this if block? <<<=====
if obj is None:
return self
if self.fget is None:
raise AttributeError("unreadable attribute")
return self.fget(obj)
def __set__(self, obj, value):
if self.fset is None:
raise AttributeError("can't set attribute")
self.fset(obj, value)
def __delete__(self, obj):
if self.fdel is None:
raise AttributeError("can't delete attribute")
self.fdel(obj)
def getter(self, fget):
return type(self)(fget, self.fset, self.fdel, self.__doc__)
def setter(self, fset):
return type(self)(self.fget, fset, self.fdel, self.__doc__)
def deleter(self, fdel):
return type(self)(self.fget, self.fset, fdel, self.__doc__)
したがって、基本的にクラスの(静的な)定義からの記述子を実際のインスタンスにコピー/挿入するのは...? – Michael
@Michael:いいえ、記述子のメカニズムがクラスでアクティブにならないようにして、インスタンス上でのみ*アクティブにすることです。どちらの場合でも '__get__'が呼び出されるのがデフォルトの動作です。 – BrenBarn