Python3:当子构造函数的参数多于父构造函数时,从继承的方法返回新的子类实例

2024-04-19 09:51:04 发布

您现在位置:Python中文网/ 问答频道 /正文

假设我有一个父类和多个子类,它们通过包含有关它们所表示的思想的更具体的信息来扩展父类。例如:

class Shape:
    def __init__(self, center):
        self.center = center


class Square(Shape):
    def __init__(self, center, side_length):
        super().__init__(self, center)
        self.side_length = side_length
        self.area = side_length ** 2


class Circle(Shape):
    def __init__(self, center, radius):
        super().__init__(self, center)
        self.radius = radius
        self.area = 3.14 * (radius ** 2)

假设我想在父类中实现一个方法,比如translate(new_center),它将返回一个新对象,该对象的中心位置与原始对象不同。因为所有子类的行为方式都应该相同(即属性self.center应该改变),所以将translate()实现为父类形状的方法是有意义的。在

如果我想在每次调用translate()时返回一个Shape类型的新对象,我们可以简单地将translate()定义为Shape的方法,如下所示:

^{pr2}$

但是,如果任何子类实例调用此方法,结果将是Shape类型,因此原始实例所包含的任何附加状态信息,例如side_lengtharea对于Square,都将丢失。另外,translate()不能定义为

    def translate(self, new_center):
        return self.__class__(new_center)

因为每个子类的构造函数需要父类构造函数不需要的额外参数。我如何实现这一点而不必重写每个子类中的父方法(避免哪一点是定义父方法的全部要点)?在


Tags: 对象方法selfinitdefarea子类length
1条回答
网友
1楼 · 发布于 2024-04-19 09:51:04

您可以复制对象并修改副本:

import copy

class Shape():
  def __init__(self, center):
    self.center = center

  def translate(self, new_center):
    new_shape = copy.copy(self) # Replace with deepcopy if needed
    new_shape.center = new_center

...

相关问题 更多 >