Python 中的装饰器

2023-09-17 22:17:44

在编程中,装饰器是一种设计模式,它动态地为对象添加额外的职责。 在 Python 中,function是一阶对象。 因此,Python 中的装饰器动态地向函数添加额外的职责/功能,而无需修改函数。

在 Python 中,一个函数可以作为参数传递给另一个函数。 也可以在另一个函数中定义一个函数,一个函数可以返回另一个函数。

因此,Python 中的装饰器是一个接收另一个函数作为参数的函数。参数函数的行为由装饰器扩展,而无需实际修改它。 可以使用@decorator语法将修饰器函数应用于函数。

让我们逐步了解 Python 中的装饰器。

考虑到我们有greet()函数,如下所示。

示例: A Function

def greet():
	print('Hello! ', end='')

现在,我们可以通过将上述函数传递给另一个函数来扩展上述函数的功能而无需对其进行修改,如下所示。

示例: A Function with Argument

def mydecorator(fn):
	fn()
	print('How are you?')
mydecorator(greet)  #output:Hello! How are you?

上面,mydecorator()函数将函数作为参数。它调用参数函数,并打印一些其他内容。因此,它扩展了greet()函数的功能,而无需对其进行修改。 但是,它不是实际的装饰器。

mydecorator()不是 Python 中的装饰器。Python 中的装饰器可以使用 @decorator_function_name 语法在任何适当的函数上定义,以扩展底层函数的功能。

下面定义了上述greet()函数的修饰器。

示例: A Decorator Function

def mydecorator(fn):
    def inner_function():        
        fn()
        print('How are you?')
    return inner_function

mydecorator()函数是装饰器函数,它将函数(任何不接受任何参数的函数)作为参数。 内部函数inner_function()可以访问外部函数的参数,因此它会在调用参数函数之前或之后执行一些代码以扩展功能。 mydecorator函数返回一个内部函数。

现在,我们可以使用 mydecorator 作为装饰器来应用于不接受任何参数的函数,如下所示。

示例: Applying Decorator

@mydecorator
def greet():
	print('Hello! ', end='')

现在,调用上述greet()函数将给出以下输出。

示例: Calling a Decorated Function

greet()  #output:Hello! How are you?

mydecorator可以应用于任何不需要任何参数的函数。例如:

示例: Applying Decorator

@mydecorator
def dosomething():
	print('I am doing something.', end='')
dosomething()  #output: I am doing something. How are you?

典型的装饰器功能如下所示。

Decorator Function Syntax

def mydecoratorfunction(some_function): # decorator function
    def inner_function(): 
        # write code to extend the behavior of some_function()
        some_function() # call some_function
        # write code to extend the behavior of some_function()
    return inner_function # return a wrapper function

内置装饰器(Built-in Decorators)

Python 库包含许多内置装饰器,作为定义属性、类方法、静态方法等的快捷方式。

Decorator描述
@property将方法声明为属性的 setter 或 getter 方法。
@classmethod将方法声明为可以使用类名调用的类的方法。
@staticmethod将方法声明为静态方法。

接下来@property了解内置装饰器。

本文内容总结: