继承:
class DerivedClassName(BaseClassName):
其中BaseClassName称为基类、父类、超类。
DerivedClassName为子类,子类继承父类的属性和方法。
例:
>>> class Father:
def hello(self):
print('正在调用父类的方法……')
>>> class Child(Father):
pass
>>> f = Father()
>>> f.hello()
正在调用父类的方法……
>>> c = Child()
>>> c.hello()
正在调用父类的方法……
如果子类有方法,则会覆盖子类里面继承的父类方法。
>>> class Child(Father):
def hello(self):
print('正在调用子类的方法……')
>>> c = Child()
>>> c.hello()
正在调用子类的方法……
>>> f = Father()
>>> f.hello()
正在调用父类的方法……
例子3:
import random as r
class Fish:
def __init__(self):
self.x = r.randint(0,10)
self.y = r.randint(0,10)
def move(self):
self.x -= 1
print('我的位置是:', self.x, self.y)
class Goldfish(Fish):
pass
class Carp(Fish):
pass
class Salmon(Fish):
pass
class Shark(Fish):
def __init__(self):
self.hungry = True
def eat(self):
if self.hungry:
print('吃货的梦想就是天天有得吃')
self.hungry = False
else:
print('太撑了,吃不下了')
fish = Fish()
fish.move()
goldfish = Goldfish()
goldfish.move()
shark = Shark()
shark.eat()
shark.move()
程序运行的结果是:
我的位置是: 1 10
我的位置是: 4 5
吃货的梦想就是天天有得吃
Traceback (most recent call last):
File “D:/作业/38讲练习.py”, line 39, in
shark.move()
File “D:/作业/38讲练习.py”, line 8, in move
self.x -= 1
AttributeError: ‘Shark’ object has no attribute ‘x’
因为Shark调用Fish父类的方法时,重新定义了自身属性__init__,把Fish的__init__方法给覆盖掉了,如果想改动,可以用一下两种方法:
①:调用未绑定的父类方法
②:使用super函数
上面例子可改为
①:
class Shark(Fish):
def __init__(self):
Fish.__init__(self) #这里的self是子类的实例对象,这里调用的是未绑定的父类方法。
self.hungry = True
②
class Shark(Fish):
def __init__(self):
super().__init__() #不需要打self参数,不用给定任何基类的名字,,super()函数会自动寻找对应父类的方法
self.hungry = True
多重继承
class DerivedClassName(Base1, Base2, Base3):
不是必要尽量避免使用多重继承,不然很可能出现不可预测的错误。
>>> class Base1:
def foo1(self):
print('我是foo1,我为Base1代言。')
>>> class Base2:
def foo2(self):
print('我是foo2,我为Base2代言。')
>>> class C(Base1, Base2):
pass
>>> c = C()
>>> c.foo1()
我是foo1,我为Base1代言。
>>> c.foo2()
我是foo2,我为Base2代言。