抽象类

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))