zoukankan      html  css  js  c++  java
  • Python_面向对象_类1

    面向对象:减少重复代码,提高效率,比函数式编程更高效

    类的创建:

    实例属性又称:成员变量,成员属性(或者字段)

    面向对象的三大特性:                                                                       

    一、封装

    把客观事物封装为抽象的类,并对外只暴露一个可用接口

    使用构造方法将内容封装到对象中,可通过对象直接或者通过self间接获取被封装的内容

     

    # 创建类
    class Foo(object):
        def __init__(self, name, age):    # 构造方法,根据创建的对象自动执行
            self.name = name
            self.age = age
    
        # 类中的方法A
        def A(self):
            Foo.name = 'yeeh'
            print('hello!', self.name)
            print('hello!', Foo.name)
    
        # 类中的方法B
        def B(self):
            print('word!',self.age)
    
    
    obj = Foo('Vera', 18)
    obj.age = 12
    obj.A()
    obj.B()
    hello! Vera
    hello! yeeh
    word! 12
    result

    二、继承

    子类拥有父类的全部方法,也可以对父类方法进行重写,并且可以定义自身的方法(一般到特殊,父类定义一些公共的方法,子类可定义自身特殊的方法)

    • 注:Python中一个子类可以继承多个父类

    对于实例属性要进行 :先重写,再继承

    # 父类
    class People(object):
        number = 0
    
        def __init__(self, name, age, sex):
            self.name = name
            self.age = age
            self.sex = sex
            self.drink()       # 因为继承,所以调用的时候,都会打印drink ()里的东西
    
        def eat(self):
            print('都可以吃东西!')
    
        def drink(self):
            People.number += 1
            print('[%s].[%s] 的年龄是[%s]' % (People.number, self.name, self.age))
    
    # 子类1
    class good_person(People):
        def __init__(self, name, age, sex, goodness):          # 先重写
            super(good_person, self).__init__(name, age, sex)    # 再继承
            self.goodness = goodness
    
        def good_ness(self):
            print('善良的[%s]做好事' % self.name)
    
    # 子类2
    class bad_person(People):
        def __init__(self, name, age, sex, sourness):
            super(bad_person, self).__init__(name, age, sex)
            self.sourness = sourness
    
        def bad_ness(self):
            print('坏人[%s]做坏事!' % self.name)
    
    
    g1 = good_person('花花', 23, '', '做好事')    # 实例化后因为父类的继承,所以直接会打印drink()
    g1.good_ness()
    b1 = bad_person('李刚', 33, '', '做了坏事')  
    b1.bad_ness()
    b1.eat()      # 继承会继承父类的所有方法
    继承
    [1].[花花] 的年龄是[23]
    善良的[花花]做好事
    [2].[李刚] 的年龄是[33]
    坏人[李刚]做坏事!
    都可以吃东西!
    result

    注:

    新式类 继承的写法:super(bad_person,self).__init__(name,age,sex)  # 利用关键字super

    旧式(经典)类 继承的写法:People.__init__(self,name,age,sex)

           有关super()继承:https://www.cnblogs.com/testview/p/4651198.html?utm_source=tuicool&utm_medium=referral 

    多继承:

    • 在3.0里及以后多继承的经典类和新式类都是采用的广度优先原则
    • 在3.0以下的版本,经典类和新式类就有深度和广度的区分

    经典类:class A: 深度优先:继承了上一级里没有这个方法就直接到上一级的上一级去寻找,找到始祖没有找到,再从继承的上一级寻找再到它的始祖

    新式类:class A(object): 广度优先  :继承的上一级,从左到右依次寻找继承的类里有没有那个方法,如果没有才再寻找上一级的上一级所继承的

     

    class A(object):
        def f1(self):
            print('我是 A')
    
    
    class B(A):
        def f2(self):
            print('我是 B')
    
    
    class C(A):
        def f3(self):
            print('我是 C')
    
    
    class D(B, C):
        def f4(self):
            print('我是 D')
    
    
    d = D()
    d.f1()      # D->B->C->A
    d.f2()      # D->B
    d.f3()      # D->B->C
    d.f4()      # D
    新式类多继承
    class A:
        def f1(self):
            print('我是 A')
    
    
    class B(A):
        def f2(self):
            print('我是 B')
    
    
    class C(A):
        def f3(self):
            print('我是 C')
    
    
    class D(B, C):
        def f4(self):
            print('我是 D')
    
    
    d = D()
    d.f1()      # D->B->A
    d.f2()      # D->B
    d.f3()      # D->B->A->C
    d.f4()      # D
    经典类多继承
    我是 A
    我是 B
    我是 C
    我是 D
    result

    三、多态

    多态:当子类和父类都存在相同的方法时,子类的 方法 覆盖了父类的方法,在代码运行时,会调用子类的方法(一种调用方式,拥有不同的执行效果),把接口进行统一(外部调用,内部可以直接转换到相应方法下)

    class Animal(object):
        def func(self):
            print('这是Animal。。')
    
    
    class dog(Animal):
        def func(self):
            print('这是dog。。')
    
    
    class pig(Animal):
        def func(self):
            print('这是pig。。')
    
        def run(self):
            print('这是pig中的run....')
    
    
    def print_func(animal):
        animal.func()
    
    
    A = Animal()
    d = dog()
    p = pig()
    
    print_func(Animal())   # 对外只暴露一个接口,但是可以直接打印多个不同的东西
    print_func(dog())
    print_func(pig())
    多态
    这是Animal。。
    这是dog。。
    这是pig。。
    result
  • 相关阅读:
    区块链价值
    区块链路线图
    Hyperledger Fabric Orderer节点启动
    使用 Docker 部署 Grafana + Prometheus 监控 MySQL 数据库
    CentOS 7.x 安装 Docker-Compose
    关于 Abp 替换了 DryIoc 框架之后的问题
    [Abp 源码分析]十七、ASP.NET Core 集成
    使用 DryIoc 替换 Abp 的 DI 框架
    《CLR Via C#》读书笔记:27.计算限制的异步操作
    《CLR Via C#》读书笔记:26.线程基础
  • 原文地址:https://www.cnblogs.com/Vera-y/p/9851153.html
Copyright © 2011-2022 走看看