• Python武器库开发-面向对象篇(六)


    面向对象篇(六)

    多态

    多态指的是一类事物有多种形态,一个抽象类有多个子类(因而多态的概念依赖于继承),不同的子类对象调用相同的方法,产生不同的执行结果,多态可以增加代码的灵活度

    实现多态的步骤:

    1、定义一个父类(Base),实现某个方法(比如:run)
    2、定义多个子类,在子类中重写父类的方法(run),每个子类run方法实现不同的功能
    3、假设我们定义了一个函数,需要一个Base类型的对象的参数,那么调用函数的时候,传入Base类不同的子类对象,那么这个函数就会执行不同的功能,这就是多态的体现。

    一个父类,他具有多个子类,不同的子类在调用相同的方法,执行的时候产生不同的形态,这个叫多态

    class Animal(object):
        """动物类"""
     
        def func(self):
            print('动物发出了声音')
     
     
    class Cat(Animal):
        """猫类"""
     
        def func(self):
            print('喵 喵 喵')
     
     
    class Dog(Animal):
        """狗类"""
     
        def func(self):
            print('汪 汪 汪 ')
     
     
    class Hero:
        def func(self):
            print('这个是英雄类的方法,不是动物类的对象')
     
     
    def work01(musen: Animal):
        musen.func()
     
     
    work01(Hero())
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    以下是实例输出的效果:

    在这里插入图片描述

    类属性与方法

    类的私有属性

    __private_attrs:两个下划线开头,声明该属性为私有,不能在类的外部被使用或直接访问。在类内部的方法中使用时 self.__private_attrs。

    类的私有属性实例如下:

    class JustCounter:
        __secretCount = 0  # 私有变量
        publicCount = 0    # 公开变量
     
        def count(self):
            self.__secretCount += 1
            self.publicCount += 1
            print (self.__secretCount)
     
    counter = JustCounter()
    counter.count()
    counter.count()
    print (counter.publicCount)
    print (counter.__secretCount)  # 报错,实例不能访问私有变量
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    执行以上程序输出结果为:

    在这里插入图片描述

    类的方法

    在类的内部,使用 def 关键字来定义一个方法,与一般函数定义不同,类方法必须包含参数 self,且为第一个参数,self 代表的是类的实例。

    self 的名字并不是规定死的,也可以使用 this,但是最好还是按照约定使用 self。

    #类定义
    class people:
        #定义基本属性
        name = ''
        age = 0
        #定义私有属性,私有属性在类外部无法直接进行访问
        __weight = 0
        #定义构造方法
        def __init__(self,n,a,w):
            self.name = n
            self.age = a
            self.__weight = w
        def speak(self):
            print("%s 说: 我 %d 岁。" %(self.name,self.age))
     
    # 实例化类
    p = people('runoob',10,30)
    p.speak()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    执行以上程序输出结果为:

    在这里插入图片描述

    类的私有方法

    __private_method:两个下划线开头,声明该方法为私有方法,只能在类的内部调用 ,不能在类的外部调用。self.__private_methods。

    类的私有方法实例如下:

    class Site:
        def __init__(self, name, url):
            self.name = name       # public
            self.__url = url   # private
     
        def who(self):
            print('name  : ', self.name)
            print('url : ', self.__url)
     
        def __foo(self):          # 私有方法
            print('这是私有方法')
     
        def foo(self):            # 公共方法
            print('这是公共方法')
            self.__foo()
     
    x = Site('博客', 'www.qianfu.com')
    x.who()        # 正常输出
    x.foo()        # 正常输出
    x.__foo()      # 报错
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    以上实例执行结果:

    在这里插入图片描述

    类方法

    类方法以cls作为第一个参数,cls表示类本身,定义时使用@classmethod装饰器。通过cls可以访问类的相关属性

    class person(object):
        tall = 180
        hobbies = []
        def __init__(self, name, age,weight):
            self.name = name
            self.age = age
            self.weight = weight
        @classmethod     # 类的装饰器
        def infoma(cls):   # cls表示类本身,使用类参数cls
            print(cls.__name__)
            print(dir(cls))
    # 1. 直接调用类的装饰器函数,通过cls可以访问类的相关属性
    person.infoma()
    # 2. 通过两步骤来实现,第一步实例化person,第二步调用装饰器  
    # Bruce = person("Bruce", 25,180)   
    # Bruce.infoma() 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    以上实例执行结果:

    在这里插入图片描述

    静态方法

    与实例方法和类方法不同,静态方法没有参数限制,既不需要实例参数,也不需要类参数,定义的时候使用@staticmethod装饰器。同类方法一样,静态法可以通过类名访问,也可以通过实例访问。

    class person(object):
        tall = 180
        hobbies = []
        def __init__(self, name, age,weight):
            self.name = name
            self.age = age
            self.weight = weight
        @staticmethod    # 静态方法装饰器
        def infoma():     # 没有参数限制,既不要实例参数,也不用类参数
            print(person.tall)
            print(person.hobbies)
    # 1. 通过类名访问
    #person.infoma()
    # 2. 通过实例访问  
    Bruce = person("Bruce", 25,180)   
    Bruce.infoma() 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    以上实例执行结果:

    在这里插入图片描述

  • 相关阅读:
    如何玩转盲盒商城小程序玩法
    PowerDesigner中的反向工程,把PDM的注释转到NAME中
    【Edibat 算法 ★★★★★★】【吸血鬼数字】Vampire Numbers
    牛视源码定制,抖音矩阵系统。来吧 和谐我。
    【毕业设计】深度学习验证码识别算法研究与实现 - python 机器视觉
    阿里本地生活全域日志平台 Xlog 的思考与实践
    如何实现浏览器的前进和后退功能?
    2023 彩虹全新 SUP 模板,卡卡云模板修复版
    【mysql篇】操作数据库的日期、字符串、数值、流程控制函数
    【解决Qt编译报错:-1: warning: **.so, not found(try using -rpath or -rpath-link)】
  • 原文地址:https://blog.csdn.net/qq_64973687/article/details/134035557