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 給定一個正整數a和一個包含任意個正整數的 列表 b,求所有<=a 的加法組合2. python-mysqldb - 這樣結構的mysql表,如何快速update3. python - Django分頁和查詢參數的問題4. 新手求教python3如何把dict循環寫入csv文件(在進行爬蟲時遇到的問題)?5. python3.x - Python not 運算符的問題6. python3.x - python連oanda的模擬交易api獲取json問題第五問7. python - 如何使用pykafka consumer進行數據處理并保存?8. python - 如何在dataframe中刪除某行當某列值為nan時?9. 小白,不知道如何解決keras在python中導入失敗?10. python - django orm 過濾日期為當天日期的數據
