Python, 這一個緩存裝飾器, 其執行流程是怎樣的?
問題描述
2017/2/6
描述比如, 考慮這樣一段代碼, 它的執行流程是怎樣的呢 ?
class Foo(object): @cached_property def foo(self):# calculate something important herereturn 42f = Foo()f.foof.foo 相關代碼
以class為基礎的緩存裝飾器
class cached_property(property): '''A decorator that converts a function into a lazy property. The function wrapped is called the first time to retrieve the result and then that calculated result is used the next time you access the value::class Foo(object): @cached_property def foo(self):# calculate something important herereturn 42 The class has to have a `__dict__` in order for this property to work. ''' # implementation detail: A subclass of python’s builtin property # decorator, we override __get__ to check for a cached value. If one # choses to invoke __get__ by hand the property will still work as # expected because the lookup logic is replicated in __get__ for # manual invocation. def __init__(self, func, name=None, doc=None):self.__name__ = name or func.__name__self.__module__ = func.__module__self.__doc__ = doc or func.__doc__self.func = func def __set__(self, obj, value):obj.__dict__[self.__name__] = value def __get__(self, obj, type=None):if obj is None: return selfvalue = obj.__dict__.get(self.__name__, _missing)if value is _missing: value = self.func(obj) obj.__dict__[self.__name__] = valuereturn value上下文環境
產品版本: Python2
操作系統: Linux
搜索相似的問題: http://stackoverflow.com/ques...
問題解答
回答1:cached_property 是 property 的subclass, 復寫了 __get__, __set__ 方法.
cached_property 是一個描述器(資料描述器),獲取屬性的時候優先從描述器獲取,即(__get__).
所以執行流程就是:f.foo -> __get__ -> 從實例字典(f.__dict__)獲取 -> 如果沒有則保存到字典并調用實際方法返回
回答2:def cached_property(func): def _deco(*args, **kwargs):print(22222222222222)ret = func(*args, **kwargs) #這是調用foo方法print(44444444444444)return ret return _decoclass Foo(object): def __init__(self):print (111111111111111111) @cached_property def foo(self):print(3333333333333)return 42f = Foo()f.foo()
相關文章:
1. python - 模擬滑動驗證碼,有源碼,求解2. 想寫一個python分析統計apache 日志文件的腳本3. 關于python的繼承的一個疑問4. python - 如何獲取rabbitmq連接的celery的個數5. python - openpyxl讀取xlsx文件把數據生成字典,中文編碼問題?6. python3中用format怎么把變量(浮點數)轉成整數打印出來7. python - 如何對列表中的列表進行頻率統計?8. python - pip install出現下面圖中的報錯 什么原因?9. python運行后沒有任何反饋要怎么排查10. Python新手問題——大txt文件按條件將多行合并
