面向对象进阶之类和类之间的关系

                                                                   Python面向对象的特征

一、继承

 在现实角度:分析阶段 对象------->抽象---------->出类

 面向对象进阶之类和类之间的关系

在程序的角度: OOP阶段 先写出父类-------->派生类继承父类------------>实例化出对象;正好与分析阶段相反;

 面向对象进阶之类和类之间的关系

得出结论:继承是抽象的结果;

现实角度:对象 ----->抽象 ----->类------> 抽象-------> 父类 ----->程序角度:————>定义父类----->派生类继承父类-------->实例化出对象

继承的作用:

1、解决代码的重用性

二、派生:新类可以派生出新的特征 和技能

class course:                                 #课程类:老师类和学生类 都有课程 所以称为组合关系
    def __init__(self,name,price,time):
        self.name=name
        self.price=price
        self.time=time

class Person:                                #人类:老师和学生类 的父类  ,他们之间的关系称为 继承
    def __init__(self,name,age,course):
        self.name=name
        self.age=age
        self.course=course

class Teacher(Person):           #老师类人类的派生类:派生了level 职业等级,也继承了父类 人类的 姓名,年龄,课程 属性
    def __init__(self,name,age,course,level):
       Person.__init__(self,name,age,course )
       self.level=level

    # def __init__(self,name,age,course):   #继承了父类 减少了代码
    #     self.name=name
    #     self.age=age
    #     self.course=course

class Students():             #学生类:派生了ID属性 学生ID,同时也继承了父类人类的 姓名,年龄,课程 属性
    def __init__(self,name,age,course,id):
        Person.__init__(self,name,age,course)
        self.id=id
         # self.name = name
                                         #继承了父类 减少了代码

#self.age = age
#self.course=course
 

 #self.age = age #self.course=course  python_obj=course('python',15800,'7m') t=Teacher('egon',34,python_obj,'高级讲师') s=Students('张根',24,python_obj,8668) print('''%s正在学习%s课程 价格:%s 周期:%s 他的学生ID:%s %s正在教%s课程 价格:%s 周期:%s 他的教师职称:%s''' %(s.name,s.course.name,s.course.price,s.course.time,s.id,t.name,t.course.name,t.course.price,t.course.time,t.level))

 三、组合:和继承一样 都是为了 解决代码重用性;

    A类  B类 之间的关系为: ----------》使用继承      例:梁山108条好汉都英雄

   A类  B类 之间的关系为: -------------》使用组合   例:梁山108条好汉都有自己的 武器

四:

1、接口和归一化设计===python中的抽象类

 接口:把一些程序应该有的功能写到一个结合体里(父类),自己不实现,让其他子类去实现;

#_*_coding:utf-8_*_
__author__ = 'Linhaifeng'
#一切皆文件
import abc #利用abc模块实现抽象类

class All_file(metaclass=abc.ABCMeta):
    all_type='file'
    @abc.abstractmethod #定义抽象方法,无需实现功能
    def read(self):
        '子类必须定义读功能'
        pass

    @abc.abstractmethod #定义抽象方法,无需实现功能
    def write(self):
        '子类必须定义写功能'
        pass

# class Txt(All_file):
#     pass
#
# t1=Txt() #报错,子类没有定义抽象方法

class Txt(All_file): #子类继承抽象类,但是必须定义read和write方法
    def read(self):
        print('文本数据的读取方法')

    def write(self):
        print('文本数据的读取方法')

class Sata(All_file): #子类继承抽象类,但是必须定义read和write方法
    def read(self):
        print('硬盘数据的读取方法')

    def write(self):
        print('硬盘数据的读取方法')

class Process(All_file): #子类继承抽象类,但是必须定义read和write方法
    def read(self):
        print('进程数据的读取方法')

    def write(self):
        print('进程数据的读取方法')

wenbenwenjian=Txt()

yingpanwenjian=Sata()

jinchengwenjian=Process()

#这样大家都是被归一化了,也就是一切皆文件的思想
wenbenwenjian.read()
yingpanwenjian.write()
jinchengwenjian.read()

print(wenbenwenjian.all_type)
print(yingpanwenjian.all_type)
print(jinchengwenjian.all_type)

 2、作用:给继承自己的子类 规范功能,使不同子类的 调用方式统一;

不同的子类都 去实现父类定义的功能,这样不同子类实例化出来的对象 的调用方法就统一了;

五:多态和多态性:很多人喜欢将多态和多态性混为一谈,然后百思不得其解,其实只要分开看,就会很明朗;

1、多态站在程序中类定义的角度:  指的是同一类事物的多种形态,(一个父类,一堆具有父类同性的子类继承他 就是多态的体现);

 动物有多种形态:人,狗,猪

  

2、多态性:站在类实例化后,对象使用类的角度人、猪、狗对象继承自一个动物类,他们继承了父类 相同的 走、说的方法;但是不同对象 调用相同的方法 就会有不同效果;

                                      人对象调用走方法:人在走

               狗对象调用走方法:狗在走

                                      猪对象调用走方法:猪在走

 

class linux_all:
    def __init__(self,name):
        self.name=name
    def read(self):
        print("正在 读取 %s 文件"%self.name)
    def write(self):
        print('正在 写入 %s 文件'%self.name)

class txt(linux_all):               #子类txt 继承了 父类Linux_all的方法: 读、写
    def __init__(self,name):
        super().__init__(name)
        super().read
        super().write

class sata(linux_all):                #子类SATA继承了 父类Linux_all的方法: 读、写
    def __init__(self,name):      
        super().__init__(name)
        super().read
        super().write
class Process(linux_all):             #子类process继承了 父类Linux_all的方法: 读、写         
    def __init__(self,name):         
        super().__init__(name)         #在程序定义角度: 所有 子类 都继承了 父类相同的 方法
        super().read                  #----------------------------------------------------------------------------------------------------
        super().write

---------------------------------------------------------------------------------------------------------------------------------------
                                         #程序调用角度:不同对象调用 继承自 父类相 同方法,执行结果却 不相同
正在 读取 文本 文件
正在 写入 文本 文件
正在 读取 磁盘 文件
正在 写入 磁盘 文件
正在 读取 进程 文件
正在 写入 进程 文件