pythonsuper继承规则,深入理解Python中的super()方法
前言
python的类分别有新式类和经典类,都支持多继承。在类的继承中,如果你想要重写父类的方法而不是覆盖的父类方法,这个时候我们可以使用super()方法来实现
python语言与C++有相似的类继承,在类定义时,python中会自定义第一个self,类似C++中this指针,指向对象自身。
python简单的类举例:
>>> class hello(object):
... def print_c():
... print"hello world!"
>>> hello().print_c()
hello world!
当然在实际中不可避免的需要类的继承,子类继承父类,正常如下:
>>> class child(hello):
... def print_c(self):
... hello().print_c()
...
>>> child().print_c()
hello world!
在python中还提供了super()机制,例子如下:
>>> class hello(object):
... def print_c(self):
... print"hello world!"
...
>>> class child(hello):
... def print_c(self):
... super(child,self).print_c()
...
>>> child().print_c()
hello world!
注意
Python2.2以前的版本:经典类(classic class)时代
经典类是一种没有继承的类,实例类型都是type类型,如果经典类被作为父类,子类调用父类的构造函数时会返回这样的错误 '''TypeError: must be type, not classobj'''
这时MRO的方法为DFS(深度优先搜索(子节点顺序:从左到右))。所以本文中使用的是新式类,而新式类的搜索算法是C3算法
class C(object):
def minus(self,x):
return x/2
class D(C):
def minus(self,x):
super(D, self).minus()
print 'hello'
上面的代码中C是父类,D是子类,我们在D类重新定义了minus方法,就是在C类的功能基础基础上新添print 'hello'功能。super在这里的作用就是在子类中调用父类的方法,这个也是在单继承常见调用super()的用法。那么问题来了
class A(object):
def __init__(self):
self.n = 10
def minus(self, m):
self.n -= m
class B(A):
def __init__(self):
self.n = 7
def minus(self, m):
super(B,self).minus(m)
self.n -= 2
b=B()
b.minus(2)
print b.n
那么上面的代码中b.n的输出是什么呢?为什么结果是2呢,而不是5呢?super(B,self).minus(m)明明是调用了父类的minus方法,可是输出结果就是2,是你要明白现在B的实例,而不是A的实例,那么传递的self.n的数值是7,而不是10.
那么对于多继承的时候,super又是怎样工作的呢?来,现在创建一个继承A的C类,然后再创建一个继承B,C的D类,看看怎样调用super是重写方法。
class C(A):
def __init__(self):
self.n = 12
def minus(self, m):
super(C,self).minus(m)
self.n -= 5
class D(B, C):
def __init__(self):
self.n = 15
def minus(self, m):
super(D,self).minus(m)
self.n -= 2
d=D()
d.minus(2)
print d.n
如上的代码输出的结果是什么呢?别心急,先看看它是怎样运行的。上面提及到新式类寻找子节点时候使用的是C3算法。那么它是怎么找呢。D->B->C->A->object。怎样才能验证这个顺序是对的呢。
D.__mro__
(, , , , )
Mro是什么呢?对于你定义的每一个类,Python 会计算出一个方法解析顺序(Method Resolution Order, MRO)列表,它代表了类继承的顺序。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
pythonsuper继承规则,深入理解Python中的super()方法相关推荐
- Python中的super()用法
Python中的super()方法设计目的是用来解决多重继承时父类的查找问题,所以在单重继承中用不用 super 都没关系:但是,使用 super() 是一个好的习惯.一般我们在子类中需要调用父类的方 ...
- Python中的super()简单用法
如果在子类中也定义了_init_()函数,那么该如何调用基类的_init_()函数: 方法一.明确指定 : class C(P):def __init__(self):P.__init__(self) ...
- python中继承是什么意思_如何理解Python中的继承?python入门
如何理解Python中的继承?如今,python编程语言深受企业和个人的喜爱.python开发工程师是近年来互联网行业非常热门的职业岗位之一.学习python的人除了零基础的,还有一部分是在职运维.在 ...
- 全面理解python中self的用法
self代表类的实例,而非类. class Test:def prt(self):print(self)print(self.__class__)t = Test() t.prt() 执行结果如下 & ...
- 深入理解Python中的全局解释锁GIL
深入理解Python中的全局解释锁GIL 转自:https://zhuanlan.zhihu.com/p/75780308 注:本文为蜗牛学院资深讲师卿淳俊老师原创,首发自公众号https://mp. ...
- pythonself用法_全面理解python中self的用法
self代表类的实例,而非类. classTest:defprt(self):print(self)print(self.__class__) t=Test() t.prt() 执行结果如下 从上面的 ...
- 【Python】Python实战从入门到精通之一 -- 教你深入理解Python中的变量和数据类型
本文是Python实战–从入门到精通系列的第一篇文章: Python实战从入门到精通之一 – 教你深入理解Python中的变量和数据类型 文章目录 1.变量 1.1 变量命名规则 1.2 变量名称错误 ...
- python class用法理解_带你全面理解python中self的用法
self代表类的实例,而非类. 执行结果如下 从上面的例子中可以很明显的看出,self代表的是类的实例.而self.class则指向类. self不必非写成self 把上面的代码改写一下. 改成thi ...
- python变量的理解_如何理解Python中的变量
在本篇文章里小编给大家分享的是关于Python中变量是什么意思的相关基础知识点,需要的朋友们可以学习下. 变量 在Python中,存储一个数据,需要定义一个变量 number1 = 1 #numbe1 ...
最新文章
- 杀戮时刻补丁(无限子弹,无限手雷)
- 2012需要一种智慧
- 美图HTTPS优化探索与实践
- 计算机组成原理指令译码,计算机组成原理实验报告指令译码器.docx
- mysql 日期 时间戳 转换
- click Utilities
- 公开课|百度天工物联网基础平台的微服务容器化落地实践
- HDU1262 寻找素数对【素数】
- FreeSwitch明明已经设置了H264,为什么通话时还是别的格式(如VP8)
- 萌新的51之旅——红外通信
- java微信公众号授权登陆
- 动手学数据分析(三)- 数据重构
- 05_grep-搜索
- 贵州支教之第二天(11月8日)
- 使用PDF编辑器进行PDF合并与PDF页面提取
- Windows目录结构、移动、复制、搜索文件及文件夹等
- mysql官网下载官网示例sql文件
- iOS 截图 截取屏幕
- 计算机休眠密码,启用或停用Windows 10睡眠唤醒密码的方法
- glibc全局构造与析构(解释了_do_global_ctors_aux)----写的相当不错!!!