抽象类作用:抽象类就是控制子类的方法的名称,要求子类必须按照父类的要求的实现指定的方法,且方法名要和父类保持一致
一、问题场景:主要使用场景是这样的
比如京东上买东西,买完东西后需要支付,京东可以使用支付宝进行支付,也可以通过微信支付,也可以通过京东白条支付,也可以通过apppay支付,
每种支付需要走内部的流程。
支付的统一入口是京东,但是点击不同的支付,需要走不同的流程,京东这边的流程就需要调用不同的函数;
那统一入口这里的调用起来就会比较麻烦
class Ali(object):
def alipay(self):
pass
class Ten(object):
def tenpay(self):
pass
class App(object):
def apppay(self):
pass
都是一个支付,阿里的支付、腾讯的支付、苹果的支付方法名都不一样、
二、使用抽象类思想解决此时我们就可以引入python中的抽线类
首先需要引入2个模块
from abc import ABCMeta
from abc import abstractmethod
实现代码如下:
from abc import ABCMeta
from abc import abstractmethod
# Payclass就是一个抽象类
class Pay(metaclass=ABCMeta):
@abstractmethod
def pay(self):
# 定义支付的基础接口
pass
class AliPay(Pay):
def ali_pay(self):
print("这是支付宝支付")
class WetPay(Pay):
def wet_pay(self):
print("这是微信支付")
class HuaweiPay(Pay):
def hua_pay(self):
print("这是华为支付")
比如我们没有按照要求实例化pay这个方法,执行代码会抛错
2、改进写法
那我们就按照要求修改代码即可,这次实例化就不会抛错:
from abc import ABCMeta, abstractmethod
class Pay(metaclass=ABCMeta):
@abstractmethod
def pay(self):
# 定义支付的基础接口
pass
class AliPay(Pay):
def pay(self):
print("这是支付宝支付")
class WetPay(Pay):
def pay(self):
print("这是微信支付")
class HuaweiPay(Pay):
def pay(self):
print("这是华为支付")
AliPay().pay()
执行可成功,结果如下
3、继续优化以在定义一个函数,搭配抽线类来实现,这个的第一个参数就是每个支付的实例,另外一个参数就是每个支付需要的参数
def pay(obj,*args,**kwargs):
obj.pay(*args,**kwargs)
详情如下:
from abc import ABCMeta, abstractmethod
class Pay(metaclass=ABCMeta):
@abstractmethod
def pay(self):
# 定义支付的基础接口
pass
class AliPay(Pay):
def pay(self, *args, **kwargs):
print("这是支付宝支付{0}".format(args[0]))
class WetPay(Pay):
def pay(self, *args, **kwargs):
print("这是微信支付{0}".format(args[0]))
class HuaweiPay(Pay):
def pay(self, *args, **kwargs):
print("这是华为支付{0}".format(args[0]))
def pay(obj, *args, **kwargs):
obj.pay(*args, **kwargs)
if __name__ == "__main__":
ali_pay = AliPay()
wet_apy = WetPay()
pay(ali_pay, 100)
pay(wet_apy, 1000)
三、使用抽象类的注意事项
1、抽象类不能被实例化
2、子类需要严格遵守父类的抽象类的规则,而孙类不需要遵守这个规则
3、如果想使用抽象类,则该类只需要继承抽象类即可
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)