python缓存装饰器,第二种方式(二)
来个简单的装饰器
def cached_method_result(fun): """方法的结果缓存装饰器""" @wraps(fun) def inner(self, *args, **kwargs): if not hasattr(fun, 'result'): result = fun(self, *args, **kwargs) fun.result = result fun_name = fun.__name__ setattr(self.__class__, fun_name, result) setattr(self, fun_name, result) return result else: return fun.result return inner
使用方式:
class MongoMixin(object): @property @utils_ydf.decorators.cached_method_result def mongo_16_client(self): mongo_var = pymongo.MongoClient(app_config.connect_url) return mongo_var
无论怎么调用mongo_16_client这个属性,都不会多次连接。
反对极端面向过程编程思维方式,喜欢面向对象和设计模式的解读,喜欢对比极端面向过程编程和oop编程消耗代码代码行数的区别和原因。致力于使用oop和36种设计模式写出最高可复用的框架级代码和使用最少的代码行数完成任务,致力于使用oop和设计模式来使部分代码减少90%行,使绝大部分py文件最低减少50%-80%行的写法。