抽象类
1 什么是抽象类
与java一样,python也有抽象类的概念但是同样需要借助模块实现,抽象类是一个特殊的类,它的特殊之处在于只能被继承,不能被实例化
2 为什么要有抽象类
如果说类是从一堆对象中抽取相同的内容而来的,那么抽象类就是从一堆类中抽取相同的内容而来的,内容包括数据属性和函数属性。
比如我们有香蕉的类,有苹果的类,有桃子的类,从这些类抽取相同的内容就是水果这个抽象的类,你吃水果时,要么是吃一个具体的香蕉,要么是吃一个具体的桃子。。。。。。你永远无法吃到一个叫做水果的东西。
从设计角度去看,如果类是从现实对象抽象而来的,那么抽象类就是基于类抽象而来的。
从实现角度来看,抽象类与普通类的不同之处在于:抽象类中只能有抽象方法(没有实现功能),该类不能被实例化,只能被继承,且子类必须实现抽象方法。这一点与接口有点类似,但其实是不同的,即将揭晓答案
3. 在python中实现抽象类(Java中出现较多)
# 定义抽象类,抽象类不允许被实例化,抽象类的子类中必须含有抽象类中的所有函数的同名函数 class Animal(metaclass = abc.ABCMeta): @abc.abstractmethod def run(self): pass @abc.abstractmethod def eat(self): pass class People(Animal): def run(self): # 名字不允许被修改 print('people is walking') def eat(self): print('people is eating') class Pig(Animal): def run(self): print('people is walking') def eat(self): print('people is eating') class Dog(Animal): def run(self): print('people is walking') def eat(self): print('people is eating') peo1 = People() pig1 = Pig() dog1 = Dog()
4 多态——python中的鸭子类
多态指的是一类事物有多种形态,比如 动物有多种形态:人,狗,猪
python崇尚鸭子类型,不用非要继承抽象类,只要长得像即可,长得像就可以有一样的方法,直接拿来用
# 继承抽象类 import abc class Animal(metaclass=abc.ABCMeta): #同一类事物:动物 @abc.abstractmethod def talk(self): pass class People(Animal): #动物的形态之一:人 def talk(self): print('say hello') class Dog(Animal): #动物的形态之二:狗 def talk(self): print('say wangwang') class Pig(Animal): #动物的形态之三:猪 def talk(self): print('say aoao') peo1 = People() dog1 = Dog() pig1 = Pig() def func(Animal): Animal.talk() func(peo1) func(dog1) func(pig1)
# EX1: 看起来都像文件,文件都有read和write方法 class File: def read(self): pass def write(self): pass class Disk: def read(self): print('disk read') def write(self): print('disk write') class Text: def read(self): print('text read') def write(self): print('text write') f = open(...) f.read() f.close() disk = Disk() text = Text() disk.read() disk.write() text.read() text.write()
# EX2:序列类型有相同的方法,属于python内置的鸭子类型 # 序列类型:列表list,元组tuple,字符串str l = list([1,2,3]) t = tuple(('a','b')) s = str('hello') print(l.__len__()) print(t.__len__()) print(s.__len__()) def len(obj): return obj.__len__() print(len(l)) print(len(t)) print(len(s))