我有 5 个类,它们都是父类的子类。我想通过为每个类添加相同的方法来为每个类定义新的子类。有没有办法动态地做到这一点?这在 OOP 术语中是否有名称?
在下面new_method
在所有情况下都是完全相同的,所以我更愿意重复一遍。
class A(MySuperClass)
class B(MySuperClass)
class C(MySuperClass)
class D(MySuperClass)
class AAA(A):
def new_method():
...
class BBB(B):
def new_method():
...
class CCC(C):
def new_method():
...
class DDD(D):
def new_method():
...
您可以通过
创建包含new_method
的新类来解决重复问题,如下所示:
class A(MySuperClass)
class B(MySuperClass)
class C(MySuperClass)
class D(MySuperClass)
class Mixin():
def new_method():
pass
class AAA(A, Mixin):
pass
这称为多重继承。在这里,您可以将继承视为专用化机制和代码共享。
除了多重继承之外,如果对代码更方便,您还可以使用装饰器:
def add_new_method(cls):
def new_method(self, ...):
pass
cls.new_method = new_method
return cls
@add_new_method
class AAA(A):
...
但是,如果您不一定需要一个新的AAA
子类,而只是想从超类向A, B, C, D
添加new_method
,那么它就像:
def new_method(self, ...):
pass
A.new_method = new_method
甚至更好。 如果MySuperClass
可以更改,您只需执行以下操作:
MySuperClass.new_method = new_method
# A, B, C and D will all have new_method automatically.
您可以使用
type
动态创建类:
class Foo(object):
def __init__(self):
print("NOTHING")
def func(self):
print("ARRRGH")
Bar = type('Bar', (Foo,), {"func": func})
Bar2 = type('Bar2', (Foo,), {"func": func})
Bar3 = ... # Put in loop if you like.
b = Bar() # This will print "NOTHING", Bar2, Bar3 works the same way.
b.func() # will print "ARRRGH"