用Python类实现装饰器

用Python类实现装饰器

为什么使用类实现装饰器?

在某些情况下,我们可能希望装饰器保存状态、初始化一些参数,或者通过对象的方法操作。这时,用类实现装饰器会显得更为灵活和合理。类装饰器允许我们:

  • 通过类的属性来存储状态。
  • 利用类的构造函数传递参数。
  • 通过类方法提供复杂的行为逻辑。

类装饰器的实现

python 复制代码
class MyDecorator:
    def __init__(self, func):
        self.func = func

    def __call__(self, *args, **kwargs):
        print("Function is being called from class-based decorator")
        return self.func(*args, **kwargs)

@MyDecorator
def say_hello():
    print("Hello, world!")

say_hello()

在这个例子中,MyDecorator 类的 init 方法接收被装饰的函数,并将其保存为类的一个属性。call 方法则使该类的实例可以像函数一样被调用,这就是为什么我们可以像函数装饰器一样使用 @MyDecorator 来装饰 say_hello 函数。

增加状态的类装饰器

通过类装饰器,我们可以轻松地维护状态。假设我们想跟踪某个函数被调用的次数,可以通过以下方式实现:

python 复制代码
class CallCounter:
    def __init__(self, func):
        self.func = func
        self.count = 0

    def __call__(self, *args, **kwargs):
        self.count += 1
        print(f"Function has been called {self.count} times")
        return self.func(*args, **kwargs)

@CallCounter
def greet(name):
    print(f"Hello, {name}!")

greet("Alice")
greet("Bob")

带参数的类装饰器

类装饰器的另一个强大功能是能够接收参数。为了实现这一点,我们可以通过 init 方法接受更多的参数。假设我们想实现一个带有自定义前缀的日志记录器,可以这样写:

python 复制代码
class Logger:
    def __init__(self, prefix):
        self.prefix = prefix

    def __call__(self, func):
        def wrapper(*args, **kwargs):
            print(f"{self.prefix}: Function {func.__name__} is called")
            return func(*args, **kwargs)
        return wrapper

@Logger("INFO")
def process_data(data):
    print(f"Processing {data}")

process_data("Dataset 1")
相关推荐
飞翔的佩奇1 小时前
【完整源码+数据集+部署教程】表盘指针检测系统源码和数据集:改进yolo11-CA-HSFPN
python·yolo·计算机视觉·数据集·yolo11·表盘指针检测
larance1 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
搏博2 小时前
基于Python3.10.6与jieba库的中文分词模型接口在Windows Server 2022上的实现与部署教程
windows·python·自然语言处理·flask·中文分词
麦兜*3 小时前
Swift + Xcode 开发环境搭建终极指南
开发语言·ios·swiftui·xcode·swift·苹果vision pro·swift5.6.3
lxmyzzs3 小时前
pyqt5无法显示opencv绘制文本和掩码信息
python·qt·opencv
萧鼎4 小时前
Python pyzmq 库详解:从入门到高性能分布式通信
开发语言·分布式·python
艾伦~耶格尔5 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
yujkss5 小时前
Python脚本每天爬取微博热搜-终版
开发语言·python
yzx9910135 小时前
小程序开发APP
开发语言·人工智能·python·yolo
飞翔的佩奇5 小时前
【完整源码+数据集+部署教程】二维码与查找模式检测系统源码和数据集:改进yolo11-CSwinTransformer
python·yolo·计算机视觉·数据集·yolo11·二维码与查找模式检测