python打卡day29@浙大疏锦行

知识点回顾

  1. 类的装饰器
  2. 装饰器思想的进一步理解:外部修改、动态
  3. 类方法的定义:内部定义和外部定义

**作业:**复习类和函数的知识点,写下自己过去29天的学习心得,如对函数和类的理解,对python这门工具的理解等,未来再过几个专题部分我们即将开启深度学习部分。

一、类的装饰器

①为类添加版本信息

复制代码
def add_version(cls):
    cls.version = "1.0.0"
    return cls

@add_version
class MyClass:
    pass

print(MyClass.version)  # 输出:1.0.0

②强制检查类方法实现

复制代码
def check_interface(cls):
    required = ['save', 'load']
    for method in required:
        if not hasattr(cls, method):
            raise NotImplementedError(f"{method}() 必须被实现")
    return cls

@check_interface
class DataProcessor:
    def save(self):
        pass

    # 若未实现load(),装饰器会抛出异常
    def load(self):
        pass

③单例模式装饰器

复制代码
def singleton(cls):
    instances = {}
    def get_instance(*args, **kwargs):
        if cls not in instances:
            instances[cls] = cls(*args, **kwargs)
        return instances[cls]
    return get_instance

@singleton
class AppConfig:
    def __init__(self):
        print("配置初始化")

c1 = AppConfig()  # 输出:配置初始化
c2 = AppConfig()
print(c1 is c2)   # 输出:True

二、装饰器思想:外部修改与动态特性

①动态日志记录

复制代码
def log_creation(cls):
    original_init = cls.__init__
    def new_init(self, *args, **kwargs):
        print(f"创建 {cls.__name__} 实例")
        original_init(self, *args, **kwargs)
    cls.__init__ = new_init
    return cls

@log_creation
class User:
    def __init__(self, name):
        self.name = name

u = User("Alice")  # 输出:创建 User 实例

②条件性装饰器应用

复制代码
DEBUG = True

def debug_decorator(cls):
    if DEBUG:
        cls.debug_mode = True
        print(f"{cls.__name__} 进入调试模式")
    return cls

@debug_decorator
class DataLoader:
    pass

print(DataLoader.debug_mode)  # 输出:True

三、类方法的定义方式

①内部定义类方法

复制代码
class Calculator:
    @classmethod
    def add(cls, a, b):
        return a + b

print(Calculator.add(3,5))  # 输出:8

②外部添加类方法

复制代码
def multiply(cls, a, b):
    return a * b

Calculator.multiply = classmethod(multiply)
print(Calculator.multiply(3,5))  # 输出:15

③外部添加实例方法

复制代码
def power(self, exponent):
    return self.value ** exponent

class Number:
    def __init__(self, value):
        self.value = value

Number.power = power

n = Number(2)
print(n.power(3))  # 输出:8

四、综合应用

复制代码
# 装饰器:自动注册子类
class ProcessorRegistry:
    registry = {}
    
    @classmethod
    def register(cls, name):
        def decorator(subclass):
            cls.registry[name] = subclass
            return subclass
        return decorator

@ProcessorRegistry.register("csv")
class CSVProcessor:
    @classmethod
    def process(cls, data):
        return f"处理CSV数据: {data}"

# 外部添加处理方法
def json_process(cls, data):
    return f"处理JSON数据: {data}"

@ProcessorRegistry.register("json")
class JSONProcessor:
    process = classmethod(json_process)

# 使用处理器
print(ProcessorRegistry.registry["csv"].process("test.csv"))  # 处理CSV数据
print(ProcessorRegistry.registry["json"].process("data.json")) # 处理JSON数据

关键点总结:

  1. 类装饰器:通过包装类实现批量功能注入

  2. 装饰器优势:非侵入式修改、动态组合功能

  3. 方法扩展

    • 内部定义:标准方式,结构清晰

    • 外部添加:灵活扩展,适合框架开发

  4. 动态特性:运行时决定功能组合,提升代码适应性

通过合理运用这些特性,可以构建出高扩展性和低耦合度的程序架构。

相关推荐
漫长的~以后2 分钟前
Edge TPU LiteRT V2拆解:1GB内存设备也能流畅跑AI的底层逻辑
前端·人工智能·edge
祝余Eleanor5 分钟前
Day37 模型可视化与推理
人工智能·python·深度学习
qq_401700415 分钟前
C语言void*
c语言·开发语言
sg_knight6 分钟前
Python 面向对象基础复习
开发语言·python·ai编程·面向对象·模型
小福气_8 分钟前
自定义组件 vue3+elementPlus
前端·javascript·vue.js
piaoroumi10 分钟前
UVC调试
linux·运维·前端
前端不太难22 分钟前
RN 调试效率低,一点小改动就需要重新构建?解决手册(实战 / 脚本 / Demo)
前端·react native·重构
是谁眉眼24 分钟前
vue环境变量
前端·javascript·vue.js
3秒一个大25 分钟前
JSX 基本语法与 React 组件化思想
前端·react.js
鹏北海-RemHusband25 分钟前
Vue 组件解耦实践:用回调函数模式替代枚举类型传递
前端·javascript·vue.js