最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

python继承与多重继承的简单讲解(代码示例)

来源:懂视网 责编:小采 时间:2020-11-27 14:21:08
文档

python继承与多重继承的简单讲解(代码示例)

python继承与多重继承的简单讲解(代码示例):本篇文章给大家带来的内容是python继承与多重继承的简单讲解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。记住以下几点:直接子类化内置类型(如dict,list或str)容易出错,因为内置类型的方法通常会忽略用户覆盖的方法,不要子
推荐度:
导读python继承与多重继承的简单讲解(代码示例):本篇文章给大家带来的内容是python继承与多重继承的简单讲解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。记住以下几点:直接子类化内置类型(如dict,list或str)容易出错,因为内置类型的方法通常会忽略用户覆盖的方法,不要子

本篇文章给大家带来的内容是python继承与多重继承的简单讲解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

记住以下几点:

直接子类化内置类型(如dict,list或str)容易出错,因为内置类型的方法通常会忽略用户覆盖的方法,不要子类化内置类型,用户自定义的类应该继承collections模块。

 def __setitem__(self, key, value):
 super().__setitem__(key, [value] * 2) # 错误案例
class AnswerDict(dict):
 def __getitem__(self, item): # 错误案例
 return 42
import collections
class DoppelDict2(collections.UserDict): # 正确案例
 def __setitem__(self, key, value):
 super().__setitem__(key, [value] * 2)
class AnswerDict2(collections.UserDict): # 正确案例
 def __getitem__(self, item):
 return 42

多重继承有关的另一个问题就是:如果同级别的超类定义了同名属性.Python如何确定使用哪个?

class DoppelDict(dict):
 def __setitem__(self, key, value):
 super().__setitem__(key, [value] * 2)
class AnswerDict(dict):
 def __getitem__(self, item):
 return 42
import collections
class DoppelDict2(collections.UserDict):
 def __setitem__(self, key, value):
 super().__setitem__(key, [value] * 2)
class AnswerDict2(collections.UserDict):
 def __getitem__(self, item):
 return 42
class A:
 def ping(self):
 print('Ping:', self)
class B(A):
 def pong(self):
 print('pong:', self)
class C(A):
 def pong(self):
 print('PONG:', self)
class D(B, C):
 def ping(self):
 super().ping()
 print('post-ping:', self)
 def pingpong(self):
 self.ping()
 super().ping()
 self.pong()
 super().pong()
 C.pong(self)
if __name__ == '__main__':
 d = D()
 print(d.pong()) # 
输出来源于B print(C.pong(d)) #输出来源于C 超类的方法都可以直接调用,此时要把实例作为显示参数传入.

python能区别调用的是哪个方法,通过方法解析顺序
>>> D.mro()
[<class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <class 'object'>]
若想把方法调用委托给超类,推荐的方式是使用内置的super()函数.

以下是对于d.pingpong()方法的解读

>>> self.ping()

Ping: <__main__.D object at 0x000002213877F2B0> post-ping: <__main__.D object at 0x000002213877F2B0> 第一个调用的是self.ping(),运行的是是D类的ping,方法.

第二个调用的的是super().ping(),跳过D类的ping方法,找到A类的ping方法.Ping: <__main__.D object at 0x000002213877F2B0>

第三个调用的是self.pong()方法,根据__mro__,找到B类实现的pong方法. pong: <__main__.D object at 0x000002213877F2B0>

第四个调用时super().pong(),也是根据__mro__,找到B类实现的pong方法. pong: <__main__.D object at 0x000002213877F2B0>

第五个调用的是C.pong(self),忽略了__mro__,找到的是C类实现的pong方法. PONG: <__main__.D object at 0x000002213877F2B0>

相关推荐:

Python中的单继承与多继承

Python类与继承讲解

文档

python继承与多重继承的简单讲解(代码示例)

python继承与多重继承的简单讲解(代码示例):本篇文章给大家带来的内容是python继承与多重继承的简单讲解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。记住以下几点:直接子类化内置类型(如dict,list或str)容易出错,因为内置类型的方法通常会忽略用户覆盖的方法,不要子
推荐度:
标签: 简单 讲解 例子
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top