class Animal(object):
def __init__(self, nlegs=4):
print '__init__ Animal'
self.nlegs = nlegs
class Cat(Animal):
def __init__(self, talk='meow'):
print '__init__ Cat'
self.talk = talk
class Dog(Animal):
def __init__(self, talk='woof'):
print '__init__ Dog'
self.talk = talk
- 为什么我的猫
tom = Cat()
没有 nlegs 属性? - 我们是否应该明确调用
Animal.__init__()
从内部Cat.__init__
,或者我们应该做一些更奇特的事情,比如super
? - 如果我想创建一只有 5 条腿的猫,我需要向
Cat.__init__
添加额外的参数吗?接口(interface)?
最佳答案
要以其他人所说的为基础,是的,您需要调用父级的 __init__
方法。
通常最好使用 super。但是,在某些情况下(特别是当您从多个类继承时),这可能是一个大问题。我将避免详细介绍,不乏 various articles which discuss it 。 (此外,其他一些“特殊”函数也有一些奇怪之处。例如,您可以执行 super(SomeCls, self).__getitem__(5)
但 super(SomeCls, self )[5]
不起作用。)
作为一个简单的例子来说明为什么使用它是一个好主意,您可以使 Dog
和 Cat
继承自 Mammal
(它继承来自 Animal
),除了 Dog
和 Cat
继承自哪个类之外,无需更改代码中的位置。
至于为什么你的tom
实例没有tom.nlegs
,那是因为你没有调用Animal
的__init__
方法。
还要记住,并非所有内容都需要在初始化时设置。对于此示例,在 __init__
方法中不要设置诸如 nlegs
之类的内容更有意义。相反,直接在类中设置即可。例如
class Mammal(object):
nlimbs = 4
def __init__(self):
print "I'm a mammal!"
class Cat(Mammal):
def __init__(self, color="calico"):
self.color = color
super(Cat, self).__init__()
print "I have {0} legs I am {1}".format(self.nlimbs, self.color)
class FiveLeggedCat(Cat):
nlimbs = 5
基本上,如果某些东西可能会在实例之间发生变化(例如猫的颜色)或需要在初始化时完成(例如打开文件),那么它可能应该在 __init__
.
否则,如果我们希望类的任何实例都相同,那么直接在类定义中设置它会更干净。
此外,以这种方式设置的属性将可用于文档工具(例如内置的 help
函数),而在初始化时设置的属性则不可用。
关于python - 简单的Python继承,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53604663/