python中的多继承_Python多继承原理与用法示例

本文实例讲述了Python多继承原理与用法。分享给大家供大家参考,具体如下:

python中使用多继承,会涉及到查找顺序(MRO)、重复调用(钻石继承,也叫菱形继承问题)等

MRO

MRO即method resolution order,用于判断子类调用的属性来自于哪个父类。在Python2.3之前,MRO是基于深度优先算法的,自2.3开始使用C3算法,定义类时需要继承object,这样的类称为新式类,否则为旧式类

从图中可以看出,旧式类查找属性时是深度优先搜索,新式类则是广度优先搜索

2018823122913911.png?2018723122943

C3算法最早被提出是用于Lisp的,应用在Python中是为了解决原来基于深度优先搜索算法不满足本地优先级,和单调性的问题。

本地优先级:指声明时父类的顺序,比如C(A,B),如果访问C类对象属性时,应该根据声明顺序,优先查找A类,然后再查找B类。

单调性:如果在C的解析顺序中,A排在B的前面,那么在C的所有子类里,也必须满足这个顺序

示例

看下面的例子

# -*- coding:utf-8 -*-

#!python2

class X(object):

def f(self):

print 'x'

class A(X):

def f(self):

print 'a'

def extral(self):

print 'extral a'

class B(X):

def f(self):

print 'b'

def extral(self):

print 'extral b'

class C(A, B, X):

def f(self):

super(C, self).f()

print 'c'

print C.mro()

c = C()

c.f()

c.extral()

根据广度搜索原则最先搜索到A,所以结果很明显,如下所示

[, , , , ]

a

c

extral b

类C没有extral函数,调用的是子类的该函数。这种类的部分行为由父类来提供的行为,叫做抽象超类.

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

本文标题: Python多继承原理与用法示例

本文地址: http://www.cppcns.com/jiaoben/python/237997.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python,`__getitem__`是一个特殊方法,用于定义对象的索引和切片行为。当您尝试通过索引或切片访问对象时,Python将调用此方法。这通常在您正在处理如列表(list)、字典(dict)、字符串(str)等可迭代对象时使用。 当类继承自内置的序列类型(例如list、str、tuple等)并使用`__getitem__`方法时,可以在类的实例实现更复杂的数据访问操作。 这是一个基本的示例,展示如何使用`__getitem__`方法来处理一个类继承自list的自定义列表: ```python class MyList(list): def __getitem__(self, index): # 可以在这里实现一些特定的索引逻辑 print("Getting item at index", index) return super().__getitem__(index) my_list = MyList([1, 2, 3, 4]) print(my_list) # 输出: "Getting item at index 1" # 输出: 2 ``` 在这个例子,当我们通过索引访问`my_list`的元素时,Python会首先调用`__getitem__`方法,然后才调用内置的`list.__getitem__`方法。这意味着我们可以在这个方法实现一些特定的逻辑,比如打印出每次访问的索引,或者返回特殊的结果。 需要注意的是,`__getitem__`方法通常返回被索引的对象,而不是该对象本身。这是因为Python的索引操作通常期望返回的是原始对象,而不是对同一对象的引用。例如,当我们使用索引访问列表时,我们期望得到的是列表的元素,而不是对列表的引用。 此外,如果你想要实现切片操作,你可以在`__getitem__`方法处理这些情况。例如,你可以定义如何根据起始和结束索引来生成一个新的序列。例如: ```python class MyList(list): def __getitem__(self, index): if isinstance(index, slice): start, stop = index.start, index.stop return MyList(super().__getitem__(start, stop)) else: return super().__getitem__(index) ``` 在这个例子,如果尝试使用切片操作访问列表,`__getitem__`方法将返回一个新的`MyList`实例,其包含了原始列表的子集。这对于处理类似列表的数据结构非常有用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值