原文查看:
http://www.ibaiyang.org/2013/01/04/python-decorator-introduction/
本篇文章将介绍python中的decorator,中文翻译为 装饰器 魔法。在这篇文章中我们将熟悉decorator使用的基本方式和基本使用例子,并利用decorator来实现一个高级的例子—缓存系统(cache system)。
Decorator已某种方式可以简化编码量,并增加了代码的可读性,这也是为何python中引入了 装饰器 魔法。我们可以看看如下例子:
def foo(self):
pass
foo = classmethod(foo)
可以看出以上的代码结构让人看起来不舒服,如果使用了装饰器,那么一切将变得美好。
@classmethod
def foo(self):
pass
在python中,装饰器(decorator)是用于修改函数,类方法的python对象。装饰器可以分为函数,类装饰器,对装饰器唯一的限制是其可调用性(callable),我们知道,函数本身是可调用的,所以如果使用类装饰器,我们就必须实现类的__call__方法。
装饰器必须用在合适的地方,否则并不能得到很好的效果,比如我们要用装饰器实现以下的功能:
def value():
return "hello world!"
使其输出结果为
<h1><li>hello world!</li></h1>
那么我们可以建立如下的装饰器:
def li(func):
return "<li>" + func() + "</li>"
def h1(func):
return "<h1>" + func() + "</h1>"
然后这样调用即可
@h1
@li
def value():
return "hello world!"
print value()
即增加了代码的可读性,又提高代码的可重用性。
看过一些简单的使用方法后,我们可以用数学语言来描述装饰器。
@f1(arg)
@f2
def func(): pass
等价于
def func(): pass
func = f1(arg)(f2(func))
当初我也在接触到装饰器一些简单的使用方式后,并不对装饰器很感兴趣,因为我们毕竟可以用其他的方式实现其功能,但是后面无意中接触到了用装饰器做cache系统,让我突然觉得有装饰器的好处和妙处。
假如,我们有一个如下递归,用来实现Fibonacci_number递归
def fib(n):
if n < 2:
return 1
return fib(n-1) + fib(n-2)
这个递归有什么问题呢,我们知道递归在通常情况下,会产生许多相同的子调用,因此我们需要一个缓存来保存中间结果,可以加速递归过程。
我们来对比一下使用cache系统之后的前后递归调用过程,以fib(5)为例:
可以发现重复调用子过程的现象消失,我还用profile对比了一下时间,后者快了许多,特别是当fib参数越大的时候,那我们如何实现这个cache系统,下面给出一个简单的版本:
from functools import wraps
def cache(func):
caches = {}
@wraps(func)
def wrap(*args):
if args not in caches:
caches[args] = func(*args)
return caches[args]
return wrap
使用方法非常简单
@cache
def fib(n):
if n < 2:
return 1
return fib(n-1) + fib(n-2)
print fib(5) #call fib so easy!
从上面我们看出,我们在没有任何代码修改的前提下实现了一个简单的cache系统,记住没有修改任何代码的前提下,还有就是并不是所有的递归都适合此类方法,比如二叉树就没有必要,当且只有重复的子过程调用时采用此方法才有实际意义,反之,画蛇添足。
Reference:
分享到:
相关推荐
1. 高度集成化:Django包含了很多常用功能,如自动化ORM系统、Form系统、Cache系统、Routing、Middleware、Template系统等,这样就能够很方便的使用这些功能,不需要自己来实现这些底层的功能。 2. 自动化Admin管理...
pip install --no-cache-dir --upgrade --force-reinstall -Iv grpcio gevent pip install -r requirements.txt 运行项目 streamlit run interview_streamlit.py # 本地启动 http://localhost:8501/ # 远程启动 ...
最少最近使用(LRU)缓存的纯Python实现。 它使开发人员可以轻松地在昂贵的函数调用上使用备忘录。 入门 这些说明将为您提供在本地计算机上运行并运行的项目的副本,以进行开发和测试。 有关如何在实时系统上部署...
基于Python Tornado实现的一套CMDB资产管理系统,前端使用Vue+Iview-admin 目前功能 支持主机记录 支持数据库记录 支持自定义IDC机房 支持Server/DB批量添加、删除 支持基于Tag管理实现用户访问资产授权 支持AWS/...
要使用激光断路器,您将需要一个rule和一个cache (电路状态存储)实例 规则 Rule是定义电路在何处断开或闭合的机制。 最大失败规则 根据最大故障次数开路的规则 from lasier . circuit_breaker . rules import ...
Caché对象服务器是一个高性能的服务器进程,它管理Python客户端和Caché数据库服务器之间的通信。 它使用标准网络协议(TCP / IP)进行通信,并且可以在Caché支持的任何平台上运行。 源代码 打开并查看此处发布
基于python的智能面试系统源码+项目说明+数据.zip ### 环境配置 1. 在环境变量中设置OPENAI_API_KEY 2. 安装依赖 ```bash pip install -r requirements.txt ``` NOTE: MAC M1版本使用一下命令安装依赖 ```bash...
我在一次面试和一个笔试时,也遇到过这个问题。 LRU的算法是比较简单的,当对key进行访问时(一般有查询,更新,增加,在get()和set()两个方法中实现即可)时,将该key放到队列的最前端(或最后端)就行了,这样就...
一、CacheCloud是做什么的CacheCloud提供一个Redis云管理平台:实现多种类型(Redis Standalone、Redis Sentinel、Redis Cluster)自动部署、解决Redis实例碎片化现象、提供完善统计、监控、运维功能、减少开发人员的...
每一个题库对应problems路径下的一个文件夹,每一个题目对应相应题库下的一个Python文件。每一个题目都要至少实现以下四个函数: solve verify input output 具体可参考problems/leetcode下我已经写好的那些题目。 ...
将简单的轻量级缓存系统实现为FastAPI中的依赖项。 安装 pip install fastapi-cache 用法示例 from fastapi import Depends , FastAPI from fastapi_cache import caches , close_caches from fastapi_cache . ...
基于LLM的智能智能面试系统DEMO 环境配置 在环境变量中设置OPENAI_API_KEY 安装依赖 pip install -r requirements.txt NOTE: MAC M1版本使用一下命令安装依赖 pip install --no-cache-dir --upgrade --force-...
其它后端用于存储和缓存的使用包括使一个模块URI或现有的存储或高速缓存实例推形式以下: >>> from shove import Shove>>> < storename> = Shove( < store> , < cache> ) 每个模块特定的URI形式都记录在其模块中。...
本书和传统同类书籍的区别是除了介绍基本的数据结构容器如栈、队列、链表、树...组实现HOCK管理、用链表实现的短信息系统中的CACHE管理,用哈希表实现W}}Server ,卜的CACHE文件管理和用哈希AV L树实现杭wS10DoS攻击等
ZakuroCache模块从粒度上讲,synskit是一个由以下组件组成的库: 成分描述zakuro_cache 包含缓存系统的实现。 zakuro_cache.loggers 在执行功能期间,将打印物排列成阵列。 zakuro_cache.decorators 执行和存储的...
代码使用了wxpy库,该库是一个用于微信个人号的Python库,可以实现微信消息的发送、接收和自动化操作。以下是代码的功能概述: 导入必要的库:代码中使用了wxpy库,该库用于实现微信个人号的操作。 初始化机器人:...
真实数据作为更改日志存储在一个几乎仅附加的外部数据存储中,每台客户端计算机都将其应用于其数据集视图。 为了控制增长,可以定期重写历史记录,以删除其影响已被以后的日志条目所覆盖的日志条目。用法先决条件...
GitFS 是一个使用 Python 写的软件,它允许你使用本地的缓存来实现 git 的断线存储服务。软件的设计目标并不是让你能节省空间,设计的目标是让你在连接断开的时候仍然希望能够在多个设备之间保持同步。 官方介绍如下...
java ...进一步的计划是编写严格和正式的测试,每个人都可以验证并有一个简单的方法来测试他们自己的输入。 PS:欢迎贡献,发现错误,更好的语言实践或任何其他事情! 只需根据您的关注打开一个问题:D
LRU(最近最少使用)缓存算法: LRUcache.py LFU(最不常用)缓存算法: LFUcache.py 代码挑战 来自真实面试的编码挑战。 目前正在更新网易和华为的编码题。 力码 LeetCode 解决方案按关键思想分类。 Python 练习 ...