我一直在学习Python,终于明白了类和对象之间的继承意味着什么。所以这是我的代码,我想确保我正确理解了它:
class Animal(object):
def __init__(self, name):
self.name = name
print self.name
def howl(self, name):
print "Eeh %s" % name
class Dog(Animal):
def __init__(self, name):
##has-a __init__ function that takes self and name parameters.
self.name = name
print "%s barks and is happy" % self.name
def sound(self, name):
print "%s barks" % name
rover = Dog("Rover")
rover.sound("Rover")
rover.howl("Rover")
为了更好地理解我的类与“基类”Animal
的行为方式,我将 print
放在各处,我可以看到 Dog
能够调用 howl
,这是其父类 Animal
中的一个函数(对吗?)
我的另一个问题是,当我使用rover = Dog("Rover")
时,它为什么使用__init__
函数调用?当 __init__
函数真正做的只是为变量 (self.name
) 设置一个值时,它的目的是什么?因为没有人调用 rover.__init__("Rover")
,并且你不能执行 print(rover = Dog("Rover"))
,为什么没有Animal
类的__init__
函数打印出来?
只是要求澄清相关类之间的类继承和函数行为。
最佳答案
您的帖子包含多个问题,我们开始吧!
1 Dog
可以调用howl
来自其父类的函数 Animal
(是吗?)
是的,你是对的。
自从你宣布你Dog
类继承自 Animal
-class Dog(Animal)
- Dog
类将具有 Animal
中声明的所有属性(包括方法)因此您可以调用howl
在狗身上。
2 当我使用 rover = Dog("Rover")
时,它怎么用__init__
函数调用?
使用 ClassName(<parameters>)
创建对象时除其他事项外,幕后发生的事情是 Python 将调用 __init__
类ClassName
中定义的方法。欲了解更多详情,请参阅the __init__
documentation ,这也说明了为什么类没有 __init__
方法将调用其父级的 __init__
方法。本文档还回答了您的子问题__init__
的目的是什么?功能...?。
总体思路是,您(几乎)永远不会调用 __init__
直接方法。
现在是有趣的部分!
3 为什么 __init__
没有Animal
的功能类打印出来?
在您的代码示例中 __init__
方法Animal
和Dog
几乎相似,即设置 name
属性并打印一些东西。唯一的区别在于它们打印的内容。因此,让我们想象一下您像这样重写您的类:
class Animal(object):
def __init__(self, name):
self.name = name
print "I am an Animal named %s" % self.name
class Dog(Animal):
def __init__(self, name):
super(Dog, self).__init__(name) # That's the important line
print "I am actually a Dog named %s, I bark too!" % self.name
rover = Dog("Rover")
# Output:
# I am an Animal named Rover
# I am actually a Dog named Rover, I bark too!
正如推荐所解释的,导入行是当我们调用 super(Dog, self).__init__(name)
时- 参见documentation - 它将检索 Dog
的父类(super class)然后我们调用__init__
初始化当前对象的方法self
- 因此设置name
并调用 print
Animal
中的声明类(class)。
完成所有这些后,您最终会正确调用 print
!
请注意,您有多种方法可以调用父类(super class)的 __init__
:
Animal.__init__(self, name)
super(Dog, self).__init__(name)
super(self.__class__, self).__init__(name) # self.__class__ is the class of self or its type.
参见this question更深入地比较各种语法。
关于python - 通过学习Pythonthehardway了解Python中的类继承,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29090369/