سؤال

هل هناك طريقة لمعرفة ما قام به تطبيق الديكور بيثون مع وظيفة التي قمت بتطبيقها.على سبيل المثال إذا كان لدي

class A(object):

   @property
   def something(self):
       return 0

أود أن أرى ما التعليمات البرمجية التي يتم تنفيذها ل something يبدو في الواقع مثل.هل هناك طريقة للقيام بذلك?

هل كانت مفيدة؟

المحلول

الديكور لا ينتج رمز;الديكور هو في الحقيقة السكر النحوي فقط:

@property
def something(self):
    return 42

يتم تفسيره حقا على أنه:

def something(self):
    return 42
something = property(something)

على سبيل المثال.التعبير التالي @ يتم تقييم علامة ، ويسمى النتيجة ، ويمر في وظيفة أو فئة التالية @ خط.مهما كان الديكور ثم يعود يستبدل الكائن الأصلي.

لأغراض الاستبطان ، فإن @ الخط هو لا الاحتفاظ بها;سيكون لديك لتحليل شفرة المصدر نفسها لاكتشاف أي الديكور الحاضر.الديكور غير ملزم بإرجاع كائن جديد;يمكنك إرجاع الكائن الأصلي دون تغيير ولا يمكنك ، مع الاستبطان ، معرفة الفرق.

أفضل رهان هو العودة إلى مصدر الديكور ثم وقراءة الكود فقط.ال property يتم تنفيذ الديكور في ج ، ولكن واصف هوتو يحتوي على تنفيذ بايثون يفعل نفس الشيء:

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):
        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__)
مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top