什么是super()
如果把类比作表演者的话,super()则是按照清单(mro)让下一位表演者“继续”他的表演
没听明白没关系,我们通过实际的例子来逐步拆解super()的运行逻辑,到时候我们就能明白这句话的含义
为什么要用super()
和拆解property一样,我们在拆解super()前也要知道我们为什么要用它
我们同样通过实际的代码示例来理解
class basicorder:
def __init__(self, price):
self.price = price
def get_total(self):
return self.price
# 返回基础价格
class memberorder(basicorder):
def get_total(self):
return self.price * 0.9
# 返回会员折后价
class promotionorder(basicorder):
def get_total(self):
if self.price > 200:
return self.price - 20
# 满减条件
else:
return self.price
a = basicorder(300)
print(a.get_total())
# 原价
b = memberorder(300)
print(b.get_total())
# 会员折后价
c = promotionorder(300)
print(c.get_total())
# 满减价格
我们定义了两种折扣机制,一种是会员价,一种是满减。我们可以根据不同的折扣方式,算出打折后的价格
但是,有一种情况我们并没有考虑,那就是两种折扣同时触发的情况。如果我们规定,当两个折扣方式同时满足时,先计算会员折后价,再考虑满减,我们该如何修改这段代码呢?
很简单,我们再定义一个类,就像这样
class basicorder:
def __init__(self, price):
self.price = price
def get_total(self):
return self.price
# 返回基础价格
class memberorder(basicorder):
def get_total(self):
return self.price * 0.9
# 返回会员折后价
class promotionorder(basicorder):
def get_total(self):
if self.price > 200:
return self.price - 20
else:
return self.price
# 触发满减
class finalorder(memberorder):
def get_total(self):
member_price = memberorder.get_total(self)
if member_price > 200:
return member_price - 20
else:
return member_price
a = basicorder(300)
print(a.get_total())
# 原价
b = memberorder(300)
print(b.get_total())
# 会员折后价
c = promotionorder(300)
print(c.get_total())
# 满减价格
d = finalorder(300)
print(d.get_total())
# 双重折扣后的价格
如果要更换折扣顺序,先计算满减,再计算会员价,只要对finalorder进行修改就好
class finalorder(promotionorder):
def get_total(self):
count_price = promotionorder.get_total(self)
return count_price * 0.9
我们这种修改,在类的数量也就是折扣方式比较少时没什么问题。但如果类的数量比较多,我们就要想办法,如何不用进行这么复杂的修改。这就是我们使用super()的原因
super()的作用
我们用super()对上面的代码进行优化
class basicorder:
def __init__(self, price):
self.price = price
def get_total(self):
return self.price
# 返回基础价格
class memberorder(basicorder):
def get_total(self):
return super().get_total() * 0.9
# 返回会员折后价
class promotionorder(basicorder):
def get_total(self):
if super().self.price > 200:
return super().get_total() - 20
else:
return super().get_total()
# 触发满减
class finalorder(memberorder, promotionorder):
def get_total(self):
return super().get_total()
a = basicorder(300)
print(a.get_total())
# 原价
b = memberorder(300)
print(b.get_total())
# 会员折后价
c = promotionorder(300)
print(c.get_total())
# 满减价格
d = finalorder(300)
print(d.get_total())
# 双重折扣后的价格
print(finalorder.mro())
# 打印mro清单
我们要注意最后的mro清单,它的输出结果是[<class '__main__.finalorder'>, <class '__main__.memberorder'>, <class '__main__.promotionorder'>, <class '__main__.basicorder'>, <class 'object'>]。这也就是当我们计算finalorder中的最后价格时,程序的执行顺序
python按照这个顺序,先从finalorder-memberorder-promotionorder-basicorder这个链条进行递进寻找,然后再从反方向basicorder-promotionorder-memberorder-finalorder进行回归计算
上面的代码就是按照这个顺序,先把原价basicorder给promotionorder计算满减,再将满减后的值给memberorder计算会员折扣价,最后把值给finalorder
return super().get_total()其实就可以理解为请mro链条上的下一位先算出结果给我
如果我们需要改变折扣计算的方式,我们也无须对finalorder中的内容进行修改,只需要修改继承顺序,也就是对这个“链条”进行调整就好
当我们修改某些类名时,我们也不用像之前的“硬编码”那样逐个修改,只要确保继承的类名正确,super()会自己按照mro这个链条进行寻找
class finalorder(promotionorder, memberorder):
def get_total(self):
return super().get_total()
结语
到此这篇关于彻底明白python中super()使用小结的文章就介绍到这了,更多相关python super() 使用内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论