Python之类的继承

有时候我们会写多个类,那么类与类之间是可以有继承关系的。

例如:

#!/usr/bin/env python
#-*-coding:utf-8-*-

class father:
    def __init__(self):
        self.fname = ‘fff‘
    def func(self):
        print ‘father.func‘

class son(father):
    def __init__(self):
        self.sname = ‘sss‘
    def bar(self):
        print ‘son.bar‘

s1 = son()
s1.bar()
s1.func()

输出结果:

son.bar
father.func
son.抽烟

从上面的例子可以看到

父类中的方法可以被子类继承并调用,调用方式为类.父类中方法名

子类可以继承父类,并重写父类中的方法

例如:

#!/usr/bin/env python
#-*-coding:utf-8-*-
class father:
    def __init__(self):
        self.fname = ‘fff‘
    def func(self):
        print ‘father.func‘
    def bad(self):
        print ‘father.抽烟喝酒‘
class son(father):
    def __init__(self):
        self.sname = ‘sss‘
    def bar(self):
        print ‘son.bar‘
    def bad(self):
        print ‘son.抽烟‘
s1 = son()
s1.bar()
s1.func()

输出结果:

son.bar
father.func
son.抽烟

子类怎么调用父类的构造函数?

在子类的构造函数中执行父类名.__init__(self)即可

#!/usr/bin/env python
#-*-coding:utf-8-*-
class father:
    def __init__(self):
        self.fname = ‘fff‘
        print ‘father.init‘
    def func(self):
        print ‘father.func‘
    def bad(self):
        print ‘father.抽烟喝酒‘
class son(father):
    def __init__(self):
        self.sname = ‘sss‘
        print ‘son.init‘
        father.__init__(self)
    def bar(self):
        print ‘son.bar‘
    def bad(self):
        print ‘son.抽烟‘
s1 = son()
s1.bar()

输出结果:

son.init
father.init
son.bar

经典类和新式类

新式类在类名后面有(object)标识。

经典类和新式类的区别:

经典类在类的多重继承时,有一个bug,就是:应该是广度优先,但在多重继承后变成了深度优先。

#!/usr/bin/env python
#-*-coding:utf-8-*-
class A:
    def __init__(self):
        print ‘This is A‘
    def save(self):
        print ‘save from A‘
class B(A):
    def __init__(self):
        print ‘This is B‘
class C(A):
    def __init__(self):
        print ‘This is C‘
    def save(self):
        print ‘save from C‘
class D(B,C):
    def __init__(self):
        print ‘This is D‘
c = D()
c.save()

输出结果

This is D
save from A

从上例可知,D类继承了B和C两个类,并且B优先继承(多重继承时,左边优先继承)

由于B类中没有save方法,而B继承了A,所以D中在继承B时,save方法应该是A类中的save方法。而D又继承了C类,所以最后D类中的最后的sava方法应该是继承C类的,但是上面的结果是D继承了A类。所以这是一个明显的bug。

我们把上例换成新式类在测试下结果:

#!/usr/bin/env python
#-*-coding:utf-8-*-
class A(object):
    def __init__(self):
        print ‘This is A‘
    def save(self):
        print ‘save from A‘
class B(A):
    def __init__(self):
        print ‘This is B‘
class C(A):
    def __init__(self):
        print ‘This is C‘
    def save(self):
        print ‘save from C‘
class D(B,C):
    def __init__(self):
        print ‘This is D‘
c = D()
c.save()

输出结果:

This is D
save from C

总结:新式类修复了经典类的一些bug,并且完全兼容经典类。所以建议使用新式类。

时间: 2025-01-15 11:55:47

Python之类的继承的相关文章

python类的继承

Python 类的一些基本概念 Python中一切皆对象,声明变量函数等的过程实际上就是它们到内存中为对象分配的空间的连接.Python中的类同Java.C++一样,有自己的属性与方法.属于一个对象或类的变量被称为域. 域有两种类型--属于每个实例/类的对象或属于类本身,它们分别被称为实例变量和类变量. 类的变量 由一个类的所有对象(实例)共享使用.所有对象共用一个类变量的拷贝.对象的变量 由类的每个对象/实例拥有.因此每个对象有自己对这个域的一份拷贝. 类的方法与普通的函数只有一个特别的区别-

python面向对象之继承与派生

一.继承 继承是一种创建新的类的方式,在python中,新建的类可以继承自一个或者多个父类,原始类称为基类或超类,新建的类称为派生类或子类. python中类的继承分为:单继承和多继承,如果是多继承的话,继承顺序有深度和广度2种 示例: class ParentClass1: #定义父类 pass class ParentClass2: #定义父类 pass class SubClass1(ParentClass1): #单继承,基类是ParentClass1,派生类是SubClass pass

Python - 对多继承以及super的一些了解

Python支持多继承,与C++一样都会出现一种问题:子类继承的多个父类又继承了同一个父类,这时就有可能会出现父类构造方法被调用多次的情况.关于这个问题,我找了一些资料,虽然没有亲自全部验证,这里我总结一下自己对这个问题的看法. Python和C++的关于这个问题的解决方案不太一样,当然Python还要看它的版本. C++用的方案是引入了虚继承的语法避免同一个类被构造了多次. Python用的方法是MRO(method resolution order,方法解析顺序) .在在Python2.3之

python D20 多继承、C3算法、super()

# 今日大纲# 1.多继承# 继承:x是一种y的时候,可以使用继承关系."is a"# 一个类同时继承多个类(python, c++)# eg:孙悟空是猴子,还是神仙,还是妖怪 # 2.经典类的MRO# 通过树形结构的深度优先遍历# 一条道走到黑(从左往右) # 3.新式类的MRO(重点.面试题)c3算法# 先拆分# 在合并,第一项的头和后面所有项的身子(除了头以外的部分)进行比较,如果都没有就拿出来,如果出现了,就跳过到后一项,后一项查一个完在跳会原来的位置继续上述动作 # 4.su

python入门18 继承和多态

继承:子类继承父类的属性和方法  class 子类名(父类1,父类2) 多态:子类重写父类的方法 判断对象是否是某个类的实例:  isinstance(object,class) 父类-汽车类 #coding:utf-8 #/usr/bin/python """ 2018-11-18 dinghanhua 继承 多态 """ '''定义一个父类-汽车类 无参构造函数,私有属性speed,方法start,speedup(每次速度+10),speed

python面向对象之继承/多态/封装

老师说,按继承/多态/封装这个顺序来讲. 子类使用父类的方法: #!/usr/bin/env python # coding:utf-8 class Vehicle: def __init__(self,name,speed,load,power): self.name = name self.speed = speed self.load = load self.power = power def run(self): print("开动啦.") class Benz(Vehicle

python小兵 面向对象继承super和c3算法

python多继承 在前面的学习过程中. 我们已经知道了Python中类与类之间可以有继承关系. 当出现了x是一种y的的时候. 就可以使?继承关系. 即"is-a" 关系. 在继承关系中. 子类?自动拥有?类中除了私有属性外的其他所有内容. python支持多继承. 一个类可以拥有多个父类. 此时, 孙悟空是一只猴子, 同时也是一个神仙. 那孙悟空继承了这两个类. 孙悟空自然就可以执行这两个类中的方法. 多继承用起来简单. 也很好理解. 但是多继承中, 存在着这样一个问题. 当两个父类

Python面向对象特性 - 继承

面向对象有3大特性:继承.多态.封装,本章介绍 Python中的 继承 特性~? 什么是继承 继承是创建类的一种方式,在 Python中支持多继承,即在创建类的时候可以继承一个或者多个父类.在继承关系中,被继承的类通常称为父类(或超类,基类),新建的类则称为子类(或派生类).?继承的优势在于可以有效地重用代码,提高代码的可读性~?继承示例: class Fu_1: # 父类 pass class Fu_2: # 父类 pass class Zi_1(Fu_1): # 单继承 pass class

python类的继承和多态

python类的继承和多态 现在属于是老年人的脑子,东西写着写着就忘了,东西记着记着就不知道了.之前学C++的时候就把类.对象这块弄得乱七八糟,现在是因为很想玩python,所以就看看python的类和对象. 就像说的,类有三个特征:封装.继承.多态. 1.封装:类封装了一些方法,可通过一定的规则约定方法进行访问权限. C++中的成员变量有public.private.ptotected. 在python中,默认的成员变量都是public的,如果成员变量前面是加两个下划线,表示该成员变量是私有的

python设计模式1:python中类的继承

在面向对象的程序设计中,继承(Inheritance)允许子类从父类那里获得属性和方法,同时子类可以添加或者重载其父类中的任何方法.在C++和Java的对象模型中,子类的构造函数会自动调用父类的构造函数,但在Python中却不是这样,你必须在子类中显示调用父类的构造函数. In [1]: class Employee: ...: def __init__(self,name,salary=0): ...: self.name = name ...: self.salary = salary ..