• 面向对象2


    一、面向对象的三大特征

    • 继承

    • 封装

    • 多态

     

    二、继承

    1. 什么是继承

        继承指的是新建类的方法, 新建的类称之为子类或者派生类, 子类继承的类叫做父类,也称之为基类或超类,可以使用base方法查看父类。

        class OldboyPeople:
            school = 'oldboy'
        
            def __init__(self, name, age, sex):
                self.name = name
                self.age = age
                self.sex = sex
        
        # 老师类: 名字,年龄,性别
        class OldboyTeacher(OldboyPeople):
            # 老师修改分数技能
            def change_score(self):
                print(f'老师[{self.name} 修改分数...]')
        
        # 学生类:  名字,年龄,性别
        class OldboyStudent(OldboyPeople):
        
            # 学生可以选择课程
            def choose_course(self, course):
                print(f'学生[{self.name}]选择课程[{course}]')
        
        stu1 = OldboyStudent('小丁丁', 95, 'female')
        tea1 = OldboyTeacher('tank', 17, 'male')
        
        print(stu1.name, stu1.age, stu1.sex)
        print(tea1.name, tea1.age, tea1.sex)

     

      2. 继承的作用

        减少代码冗余

     

      3. 继承背景下对象属性的查找顺序

        对象名称空间——类——父类

        若查找的属性在子类中存在,不管父类中存不存在,以子类为准

        class Foo:
        
            def f1(self):
                print('Foo.f1')
        
            def f2(self):
                print('Foo.f2')
                self.f1()
        
        
        class Soo(Foo):
            def f1(self):
                print('Soo.f1')
        
        
        soo_obj = Soo()
        soo_obj.f2()
        
        输出
        Foo.f2
    Soo.f1

     

     

    三、派生

    1. 定义 子类继承父类的属性,并派生出新的属性

    2. 子类派生时重用父类属性的两种方法

      1. 直接调用父类的init方法

    class OldboyPeople:
      def __init__(self, name, age, sex):
        self.name = name
        self.age = age
        self.sex = sex
            
    class OldboyTeacher(OldboyPeople):
      # 等级, 薪资
      def __init__(self, name, age, sex, level, sal):
        OldboyPeople.__init__(self, name, age, sex)
        self.level = level
        self.sal = sal
            
            
    class OldboyStudent(OldboyPeople):
      # 课程
      def __init__(self, name, age, sex, course):
        OldboyPeople.__init__(self, name, age, sex)
        self.course = course
            
      def choose_course(self):
        print(f'学生{self.name}选择课程{self.course}')

        2. 使用super()方法,通过‘.’指向父类的名称空间

    class OldboyTeacher(OldboyPeople):
      # 等级, 薪资
      def __init__(self, name, age, sex, level, sal):
        super().__init__(name, age, sex)
        self.level = level
        self.sal = sal
            
            
    class OldboyStudent(OldboyPeople):
      # 课程
      def __init__(self, name, age, sex, course):
        super().__init__(name, age, sex)
        self.course = course
            
      def choose_course(self):
        print(f'学生{self.name}选择课程{self.course}')

    四、新式类与经典类

    1. 新式类

      • 继承object的类都称之为新式类

      • python3中,默认最终继承object,因此都是新式类

     

       2. 经典类

      • python2中,没有继承object的类都是经典类

     

     

      3. mro()

        用来查看当前类的继承顺序

    class A:
      # x = 2
      pass
    class B:
      # x = 3
      pass

    # 多继承情况下: class C(A, B):   # print('C...')   # x = 1   pass # [<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>] print(object) print(C.mro())

    输出
    <class 'object'> [<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>]
    1. 菱形继承

      • 经典类:深度优先

      • 新式类:广度优先

    class A:
      # def test(self):
      #     print('from A')
      pass
        
    class B(A):
      # def test(self):
      #     print('from B')
      pass
        
    class C(A):
      def test(self):
        print('from C')
        pass
        
    class D(B):
      # def test(self):
      #     print('from D')
      pass
        
    class E(C):
      # def test(self):
      #     print('from E')
      pass
        
    class F(D,E):
      # def test(self):
      #     print('from F')
      pass
        
        
    # 新式类: F-D-B-E-C-A-object
    f1 = F()
    f1.test()
        
    # 经典类: F-D-B-A-E-C

    五、通过继承添加json模块支持的数据类型

    1. 直接转成str

    import json
    from datetime import date, datetime
        
        
    #开发者的角度: 直接转成str
    dict1 = {
      'name': 'tank',
      'today': str(datetime.today()),
      'today2': str(date.today())
          }
        
    res = json.dumps(dict1)
    print(res)

     

      2. 修改json源码

    class MyJson(json.JSONEncoder):
        def default(self, o):
    
            # 子类派生的功能
            # 判断o是否式datetime的一个实例
            if isinstance(o, datetime):
                return o.strftime('%Y-%m-%d %X')
            elif isinstance(o, date):
                return o.strftime('%Y-%m-%d')
            else:
                # 继承父类的default方法的功能
                return super().default(self, o)
    
    
    dict1 = {
        'name': 'tank',
        'today': datetime.today(),
        'today2': date.today()
    }
    
    res = json.dumps(dict1, cls=MyJson)  # cls=None,默认指向的是原json的JSONEncoder
    print(res)
  • 相关阅读:
    随机生成三十个二年级的加减乘除法的题目代码
    学习进度表_四周
    返回一个整数数组中最大子数组的和1
    学习进度表_三周
    四则运算4
    构建之法读书笔记2
    学习进度表_二周
    四则运算3
    四则运算2
    单元测试
  • 原文地址:https://www.cnblogs.com/binyuanxiang/p/11711189.html
Copyright © 2020-2023  润新知