黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

python 屬性搜索優先級和descriptor

系統 2235 0

屬性搜索優先級和descriptor

          
            ########################
# 定義
########################

# 數據描述符
class DataDesc(object):
    def __init__(self, *args, **kwargs):
        pass

    def __get__(self, instance, cls):
        print(instance is None)
        return 'DataDesc'

    def __set__(self, instance, value):
        return None

    def __delete__(self, instance):
        return None


# 數據描述符
class DataDesc2(object):
    def __init__(self, *args, **kwargs):
        pass

    def __get__(self, instance, cls):
        return 'DataDesc2'

    def __set__(self, instance, value):
        return None


# 非數據描述符
class NonDataDesc(object):
    def __init__(self, *args, **kwargs):
        pass

    def __get__(self, instance, cls):
        print(instance is None)
        return 'NonDataDesc'


class Foo(object):
    test_attr = DataDesc()
    test_attr2 = DataDesc()
    test_attr3 = NonDataDesc()
    test_attr4 = 'test_attr4'

    def __getattr__(self, item):
        return 'hehe__getattr__'


########################
# 一般情況
########################
foo = Foo()
'''
1. foo.__dict__['test_attr4']
2. for cls in Foo.__mro__:
       cls.__dict__['test_attr4']
3. foo.__getattr__('test_attr4')
'''
print(foo.test_attr4)
foo.__dict__['test_attr4'] = 666
print(foo.test_attr4)
print(id(foo.test_attr4) == id(foo.__dict__['test_attr4']))
foo.__dict__.pop('test_attr4')
print(foo.test_attr4)
print(foo.test_attr5)
print(foo.__getattr__('test_attr5'))

########################
# 數據型描述符
########################
foo = Foo()
'''
1. type(foo).__dict__['test_attr'].__get__(foo, type(foo))
2. foo.__dict__['test_attr4']
3. for cls in Foo.__mro__:
       cls.__dict__['test_attr4']
4. foo.__getattr__('test_attr4')
'''
print(foo.test_attr)
foo.__dict__['test_attr'] = 666
print(foo.test_attr)
print(id(foo.test_attr) == id(foo.__dict__['test_attr']))
delattr(Foo, 'test_attr')
print(foo.test_attr)
print(id(foo.test_attr) == id(foo.__dict__['test_attr']))

########################
# 非數據型描述符
########################
foo = Foo()
'''
1. foo.__dict__['test_attr4']
2. type(foo).__dict__['test_attr'].__get__(foo, type(foo))
3. for cls in Foo.__mro__:
       cls.__dict__['test_attr4']
4. foo.__getattr__('test_attr4')
'''
print(foo.test_attr3)
foo.__dict__['test_attr3'] = 666
print(foo.test_attr3)
print(id(foo.test_attr3) == id(foo.__dict__['test_attr3']))
del foo.test_attr3
print(foo.test_attr3)

########################
# 類調用描述符
########################
'''
FOO.__dict__['test_attr'].__get__(None, FOO)
'''
print(Foo.test_attr2)
print(Foo.test_attr3)

########################
# __getattribute__
########################
'''
如果被重寫,上面代碼介紹的東西會被覆蓋掉
除非函數內部調用object.__getattribute__
否則別這么干
'''


class Foo2(object):
    test_attr = DataDesc()
    test_attr2 = DataDesc()
    test_attr3 = NonDataDesc()
    test_attr4 = 'test_attr4'

    def __getattribute__(self, item):
        return 'in __getattribute__'


foo = Foo2()
print(foo.test_attr3)

########################
# 例子
########################
import time


class LazyProperty(object):
    def __init__(self, func):
        self.func = func

    def __get__(self, instance, cls):
        if instance is not None:
            val = self.func(instance)
            setattr(instance, self.func.__name__, val)
            return val


class Foo3(object):
    @LazyProperty
    def method(self):
        time.sleep(5)
        return 666


foo3 = Foo3()
time1 = time.time()
print(foo3.method)
time2 = time.time()
print(time2 - time1)
print(foo3.method)
print(time.time() - time2)

          
        

更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論