Python之装饰器

简介:

在Python中一切皆对象,函数是一等对象。这意味着可以通过名字引用函数。

1
2
3
4
5
6
7
8
9
10
11
12
13
>>> a=123
>>> a
123
>>> name= 'zeng'
>>> name
'zeng'
>>> def func():
...     print  "hello!"
...
>>> func
< function  func at 0x1066bdc08>
>>> func()
hello!

从上面的例子可以看出,调用函数时只需要函数名后面加‘()’即可。如果不加,则返回函数内存地址。


函数还可以作为值传递

1
2
3
4
5
6
7
8
>>> def func():
...     print  "hello!"
>>> dict = { 'func' :func}
>>> aaa = dict[ 'func' ]
>>> aaa
< function  func at 0x1066bdc08>
>>> aaa()
hello!

从上面的例子可以看到,函数可以作为值保存到字典dict的‘func’这个key中。然后将函数这个值又可以赋值给变量aaa,当执行aaa时,返回的是函数的内存地址,如果调用函数则执行aaa()



函数可以作为值传递,那么是否可以作为参数传递呢?

1
2
3
4
5
6
7
8
9
>>> def func1():
...      return  "I am an amazing function"
...
>>> def printer(arg):
...     print  "The function passwd to me says:"  + arg()
...
>>> printer(func1)
The  function  passwd  to me says:I am an amazing  function
>>>

从上面的例子可以看到,函数完全可以作为参数传递。而且传递给函数的函数还可以被调用


装饰器的基础:

本质上装饰器就是一个以另一个函数作为参数的函数。看下面的例子:


def identity_decorator(func):
    def wrapper():
        func()
    return wrapper
def a_function():
    print "I'm a normal function."

# 'decorated_function' 是 'identity_function' 返回的函数,也就是嵌套函数 'wrapper'
decorated_function = identity_decorator(a_function)

#如下调用'identity_function'返回的函数
decorated_function()
# >>> I'm a normal function

上面的例子中当执行decorated_function()时,调用了decorated_function函数,而

decorated_function = identity_decorator(a_function),所以调用decorated_function()函数,实际上就是调用了 identity_decorator( )函数。而 identity_function( )函数返回的是wrapper( )函数的内存地址。所以调用 identity_decorator( )函数最终会调用wrapper( )函数,而wrapper( )函数则是调用了

identity_decorator(func)函数的参数。这个参数本身就是a_function()函数,所以最终结果是调用了a_function()函数,输出结果就是a_function()的输出结果。

I'm a normal function

那么问题来了,上面这个例子饶了一大圈,结果就是调用了a_function()函数,那么完全可以直接调用a_function()函数,何必兜一圈子呢,所以上面这个例子是一个没有意义的装饰器。


下面看一个有意义的装饰器

def login(func):
    def inner(arg):
        print "Welcome login"
        func(arg)
    return inner

@login
def buy(name):
    print "%s 快下单秒杀吧!" % name
buy('zenge')
输出结果:
Welcome login
zenge 快下单秒杀吧!

上面代码中@login是装饰器的写法。意思是将@login下面的函数作为login()函数的参数。也可以这样写

buy = login(buy)

当执行@login时,实际上就是执行了buy = login(buy)

意思是将buy函数作为参数调用login函数,并将结果赋值给buy这个变量中。而login函数返回的是inner函数的内存地址。所以当执行buy('zeng')时,其实是调用inner函数,此时会执行

print "Welcome login"
func(arg)

 执行func(arg),则实际上是执行login函数的参数这个函数,这个函数就是buy函数,所以此时会调用buy函数,并将‘zeng’这个参数传递到buy函数中,所以结果就是既执行了inner函数,又执行了buy函数。










本文转自 曾哥最爱 51CTO博客,原文链接:http://blog.51cto.com/zengestudy/1828019,如需转载请自行联系原作者
目录
相关文章
|
9天前
|
监控 Python
Python中的装饰器:提升代码灵活性与可读性
在Python编程中,装饰器是一种强大的工具,能够提升代码的灵活性和可读性。本文将介绍装饰器的基本概念、使用方法以及实际应用场景,帮助读者更好地理解和利用这一功能。
|
12天前
|
缓存 监控 Python
解密Python中的装饰器:优雅而强大的编程利器
Python中的装饰器是一种强大而又优雅的编程工具,它能够在不改变原有代码结构的情况下,为函数或类添加新的功能和行为。本文将深入解析Python装饰器的原理、用法和实际应用,帮助读者更好地理解和利用这一技术,提升代码的可维护性和可扩展性。
|
30天前
|
缓存 算法 测试技术
Python中的装饰器:原理与实践
【2月更文挑战第29天】 在Python编程领域,装饰器是一种强大的工具,它允许我们在不修改原始函数代码的情况下,增加或修改函数的行为。本文将深入探讨Python装饰器的概念、实现原理以及实际应用,帮助读者掌握这一技术并在实际项目中灵活运用。
|
2天前
|
数据安全/隐私保护 Python
Python中的装饰器:提升代码可读性与灵活性
Python中的装饰器是一种强大的工具,可以在不改变函数原有逻辑的情况下,为函数添加额外的功能。本文将介绍装饰器的基本概念和用法,并通过实例演示如何利用装饰器提升代码的可读性和灵活性,使代码更加简洁、易于维护。
|
4天前
|
程序员 Python
Python中的装饰器:提升代码可读性与灵活性
在Python编程中,装饰器是一种强大的工具,可以在不修改原始代码的情况下,动态地添加功能。本文将深入探讨Python中装饰器的原理、用法和实际应用,以及如何利用装饰器提升代码的可读性和灵活性。
|
6天前
|
缓存 开发者 Python
深入探讨Python中的装饰器:提升代码可读性与灵活性
在Python编程中,装饰器是一种强大的工具,可以在不修改原始函数代码的情况下,对其行为进行扩展或修改。本文将深入探讨装饰器的原理和用法,以及如何利用装饰器提升代码的可读性和灵活性,为Python开发者提供更加优雅和高效的编程方式。
|
7天前
|
测试技术 开发者 Python
Python中的装饰器:优雅而强大的函数修饰工具
在Python编程中,装饰器是一种强大的工具,用于修改函数或方法的行为。本文将深入探讨Python中装饰器的概念、用法和实际应用,以及如何利用装饰器实现代码的优雅和高效。
|
17天前
|
缓存 数据安全/隐私保护 Python
Python中的装饰器:提升代码灵活性和可维护性
Python中的装饰器是一种强大的工具,能够在不修改原始函数代码的情况下,为函数添加额外的功能。本文将深入探讨装饰器的原理、用法以及实际应用场景,帮助读者更好地理解和利用Python中的装饰器提升代码的灵活性和可维护性。
|
23天前
|
缓存 程序员 Python
深入理解Python装饰器:从概念到应用
Python装饰器是函数,用于在不修改原代码的情况下为函数添加新功能。它们基于Python的函数一阶对象特性,通过`@decorator`语法应用。装饰器工作原理是接收函数作为参数,创建新函数对象并在调用时执行额外操作。常见应用场景包括日志记录、性能分析、权限校验和缓存。装饰器增强了代码的可读性和可维护性。
|
25天前
|
测试技术 Python
Python中的装饰器:提升代码可读性和灵活性
在Python编程中,装饰器(Decorator)是一种强大的工具,它可以在不修改原有代码的情况下,为函数或方法添加额外的功能。本文将深入探讨Python中装饰器的使用方法和实际应用,帮助读者更好地理解和运用这一重要的编程概念。

热门文章

最新文章