python - 简单的Python继承

标签 python inheritance constructor

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
  1. 为什么我的猫 tom = Cat()没有 nlegs 属性?
  2. 我们是否应该明确调用 Animal.__init__()从内部Cat.__init__ ,或者我们应该做一些更奇特的事情,比如 super
  3. 如果我想创建一只有 5 条腿的猫,我需要向 Cat.__init__ 添加额外的参数吗?接口(interface)?

最佳答案

要以其他人所说的为基础,是的,您需要调用父级的 __init__ 方法。

通常最好使用 super。但是,在某些情况下(特别是当您从多个类继承时),这可能是一个大问题。我将避免详细介绍,不乏 various articles which discuss it 。 (此外,其他一些“特殊”函数也有一些奇怪之处。例如,您可以执行 super(SomeCls, self).__getitem__(5)super(SomeCls, self )[5] 不起作用。)

作为一个简单的例子来说明为什么使用它是一个好主意,您可以使 DogCat 继承自 Mammal (它继承来自 Animal),除了 DogCat 继承自哪个类之外,无需更改代码中的位置。

至于为什么你的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/

相关文章:

wpf - DataTemplate 具有非空构造函数的 ViewModel ?

java - 使用反射获取构造函数(或方法)参数注释

具有灵活数组成员的 Python ctypes 结构到 bytearray

Python pandas 替换列中的值

python - 文档中的 Mongoengine creation_time 属性

c++ - 函数可以接受抽象基类作为参数吗?

Python 速度违规计算器返回 TypeError 错误

java - 如何避免自定义 Java 异常类中的重复

c++ - 为什么这段代码中继承的函数隐藏在基类中?

c# - 第二次在c#中调用构造函数