`
把酒泯恩仇
  • 浏览: 27108 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

用python实现一个简单的cache系统

阅读更多

原文查看:

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:


-----------------打造高质量的文章 更多关注 把酒泯恩仇---------------

为了打造高质量的文章,请  推荐  一下吧。。。。谢谢了,请关注我后续的文章,会更精彩哦

请关注sina微博:http://weibo.com/baiyang26

把酒泯恩仇官方博客:http://www.ibaiyang.org 【推荐用google reader订阅】

把酒泯恩仇官方豆瓣:http://www.douban.com/people/baiyang26/

如果您想转载本博客,请注明出处

如果您对本文有意见或者建议,欢迎留言

2
2
分享到:
评论

相关推荐

    Python-所有ApolloClient20cache实现的简单持久化

    本文将深入探讨标题中的"Python-所有ApolloClient20cache实现的简单持久化",以及与之相关的标签"Python开发-数据缓存"。 Apollo是一个配置中心,它允许应用程序动态地获取和更新配置,而无需重启服务。在Python中...

    计算机体系结构Cache模拟python.zip

    本项目通过Python实现Cache模拟,旨在帮助学生深入理解Cache的工作原理及其优化策略。 在Python实现Cache模拟时,主要涉及以下几个核心概念: 1. **Cache的基本结构**:Cache通常由多个存储块(或称为行)组成,每...

    Python-rediscache一个Redis的缓存装饰器

    总结来说,"Python-rediscache"是一个便捷的工具,它将Redis的强大缓存能力与Python的装饰器机制结合,使得在Python应用中实现高效的数据缓存变得简单易行。通过灵活的配置和使用,开发者可以有效地提升程序性能,...

    Python-一个采用Python开发的简单缓存服务器

    标题中的"Python-一个采用Python开发的简单缓存服务器"揭示了我们将探讨如何使用Python构建这样一个系统。 缓存服务器是提高应用性能的关键技术之一,它通过存储常用数据或计算结果,减少对原始数据源(如数据库或...

    Python库 | django-cache-lock-0.2.5.tar.gz

    Django是用Python编写的一个开源Web框架,广泛应用于后端开发。这个库的版本是0.2.5,通常更新版本意味着修复了旧版本的问题或增加了新功能。 在描述中提到了“python库”,这进一步确认了该资源是用于Python编程的...

    PyPI 官网下载 | diskcache-1.3.5.tar.gz

    标题中的“PyPI 官网下载 | diskcache-1.3.5.tar.gz”表明这是一个在Python Package Index(PyPI)官方源上发布的软件包,名为`diskcache`,版本号为1.3.5,格式为tar.gz压缩文件。PyPI是Python开发者发布和分发他们...

    Python + Flask 实现简单的验证码系统

    本文将介绍如何使用Python和Flask构建一个简单的验证码系统。验证码在现代互联网中扮演着重要的角色,用于防止自动化程序的恶意操作,如机器人注册或垃圾邮件发送。虽然有多种复杂的验证码形式,但本文将专注于字符...

    Python-一个简单小巧可定制化轻量级的基于内存的Python缓存组件

    标题中的“Python-一个简单小巧可定制化轻量级的基于内存的Python缓存组件”指的是一种Python库,它设计用于实现简单的内存缓存功能。这类组件在处理大量数据或者需要频繁读取已计算结果时特别有用,因为它可以减少...

    Python实现监控MySQL性能指标

    ### Python 实现监控 MySQL 性能指标 #### 概述 在现代数据库管理中,对 MySQL 的性能监控是一项至关重要的...通过上述步骤,我们可以有效地使用 Python 监控 MySQL 的性能指标,从而更好地管理和优化数据库系统。

    Python库 | oslo.cache-1.37.0-py2.py3-none-any.whl

    这个`oslo.cache-1.37.0-py2.py3-none-any.whl`文件是该库的一个发行版本,适用于Python 2和Python 3环境,且不依赖于特定的硬件或操作系统。 ### 1. 缓存的重要性 在处理大量数据或高并发请求时,缓存能显著提高...

    python Django web 联通用户管理系统实训代码

    1. 高度集成化:Django包含了很多常用功能,如自动化ORM系统、Form系统、Cache系统、Routing、Middleware、Template系统等,这样就能够很方便的使用这些功能,不需要自己来实现这些底层的功能。 2. 自动化Admin管理...

    Python高性能编程_python进阶_python高性能_

    PyPy则是Python的一个替代实现,使用JIT(Just-In-Time)编译器,可以显著提升性能。 10. **代码剖析与优化工具**:如cProfile、line_profiler等可以帮助找出代码中的性能瓶颈。了解如何使用这些工具,可以针对性地...

    Python库 | red_cache-0.2.5-py3-none-any.whl

    今天我们将深入探讨一个名为`red_cache`的Python库,它在0.2.5版本中的应用和特点。这个库的名称暗示了它可能与数据缓存有关,尤其是与Redis这种流行的数据存储系统相结合。让我们一起揭开`red_cache`的神秘面纱,...

    Python-ubelt一个Python工具带包括额外的电池

    Python-ubelt是一个强大的Python库,它的设计理念是为Python开发者提供更多的“额外电池”。这个库包含了各种实用工具,旨在提高开发效率,解决日常编程中遇到的各种问题。ubelt的命名来源于“utility belt”,暗示...

    python简单缓存系统.zip

    Python中,`functools.lru_cache` 是一个内置的装饰器,用于实现最近最少使用的(LRU)缓存策略。例如: ```python from functools import lru_cache @lru_cache(maxsize=32) def fib(n): if n return n return ...

    PyPI 官网下载 | mo-cache-0.0.3.tar.gz

    "mo-cache-0.0.3.tar.gz"是一个遵循Python打包标准的压缩文件,它包含了名为"mo-cache"的Python库的版本0.0.3。这种文件格式通常用于存储源代码包,便于开发者进行安装和使用。`.tar`是一个归档文件,用于集合多个...

    Python库 | django-cache-toolbox-1.4.0.tar.gz

    Django是一个高级的、开源的Web框架,用Python编写。它遵循模型-视图-控制器(MVC)的设计模式,简化了开发过程,包括数据库交互、URL路由、模板渲染等。Django的核心特性包括ORM(对象关系映射),自动生成管理界面...

    python解析xmind的工具[xmindparser]

    `xmindparser`是一个专为Python设计的工具,用于解析XMind文件。XMind是一款流行的思想导图和头脑风暴软件,它允许用户创建结构化的思维图表,方便地组织和分享想法。`xmindparser`则提供了一个方便的接口,帮助...

    Python库资源大全

    - algorithms:提供了Python实现的各种算法。 - PyPattern:一个简洁的库,用于实现常见的设计模式。 - python-patterns:包含Python中的设计模式集合。 - sortedcontainers:快速的纯Python排序容器,如Sorted...

    Python-joblib使用Python方便的进行并行计算

    总的来说,joblib是Python中实现并行计算的一个理想选择,特别是对于需要频繁调用相同计算任务的情况,通过缓存和并行化可以大大提高代码执行效率。然而,在使用时应根据具体任务需求和资源状况进行适当优化。

Global site tag (gtag.js) - Google Analytics