
本文旨在介绍如何在python中实现一个通用的方法调用逻辑,即在调用多个特定方法时,自动执行一个通用的方法。不同于常见的装饰器或继承方式,本文将提供一种简洁明了的实现方案,避免使用装饰器、包装方法或继承,直接在方法调用前后插入通用逻辑。
在Python中,我们经常需要在调用某些特定方法时,执行一些通用的逻辑,例如日志记录、权限检查或性能监控。通常,我们可以使用装饰器或继承来实现这个目的。但是,如果不想使用装饰器或继承,有没有其他方法可以实现呢?答案是肯定的。
实现原理
核心思想是在调用目标方法之前和之后,显式地调用通用方法。这可以通过将目标方法赋值给一个新的变量,然后在这个新的变量中调用通用方法和目标方法来实现。
立即学习“Python免费学习笔记(深入)”;
具体实现
以下是一个简单的示例,演示了如何在不使用装饰器或继承的情况下,实现方法调用的通用逻辑:
def common_method(): print("通用方法被调用!") def wrap(method): def wrapped(*args, **kwargs): common_method() method(*args, **kwargs) common_method() return wrapped def method_1(): print("方法 1 被调用!") # 方法 2 可以接收参数 def method_2(x, y): print(f"方法被调用,参数为 {x} 和 {y}!") method_1_wrapped = wrap(method_1) method_1_wrapped() # 甚至可以覆盖原始函数名 method_2 = wrap(method_2) method_2(3.14, y=42)
代码解释
- common_method(): 定义了一个通用的方法,在目标方法调用前后都会被执行。
- wrap(method): 定义了一个包装函数,接收一个方法作为参数,并返回一个新的方法。这个新的方法在调用目标方法之前和之后都会调用common_method()。
- method_1() 和 method_2(): 定义了两个目标方法,它们将在common_method()的调用之间被执行。
- method_1_wrapped = wrap(method_1): 将method_1()方法传递给wrap()函数,并将返回的新方法赋值给method_1_wrapped。
- method_1_wrapped(): 调用method_1_wrapped(),它会先调用common_method(),然后调用method_1(),最后再次调用common_method()。
- method_2 = wrap(method_2): 将method_2()方法传递给wrap()函数,并将返回的新方法赋值给method_2。这实际上覆盖了原始的method_2函数。
- method_2(3.14, y=42): 调用method_2(),它会先调用common_method(),然后调用method_2(3.14, y=42),最后再次调用common_method()。
优点
- 简单易懂: 代码逻辑清晰,易于理解和维护。
- 无需装饰器或继承: 避免了使用装饰器或继承带来的复杂性。
- 灵活性: 可以轻松地将通用逻辑应用于任何方法,而无需修改方法的定义。
- 可定制性: 可以灵活地控制通用方法在目标方法之前或之后执行,甚至可以根据需要多次调用通用方法。
注意事项
- 这种方法需要显式地将目标方法赋值给一个新的变量,或者覆盖原始函数名。
- 如果目标方法有很多,可能会导致代码冗余。
总结
本文介绍了一种在Python中实现方法调用的通用逻辑的方法,它避免了使用装饰器或继承,而是通过显式地调用通用方法来实现。这种方法简单易懂,灵活性强,适用于需要在多个方法调用前后执行通用逻辑的场景。虽然可能存在代码冗余的问题,但在某些情况下,它仍然是一个不错的选择。


