【第四周】第 3 节:类与对象(二)

第四周-第三节课

类属性和实例属性

  • 类属性

    • 通过类对象可以直接访问的属性

    • 抽象概念的固有属性, 要考虑当前抽象概念的普适性

      # 贴标签不是一个特别好的抽象, 原因他没有一个普适性
      class Developer:
          programing_language = None
          busy = True
      
      • 私有属性

        不希望外部更改, 只作用于类内部

        • 通过__变量名来声明私有属性

          class Lottery:
              __items = ["mac", "ipad", "iphone"]
          
        • 通过类._类名__变量名来访问私有属性

          print(Lottery._Lottery__items)
          
  • 实例属性

    • 绑定在实例上的属性, 只能通过该实例进行访问

    • 实例的自有属性

      class Developer:
          programing_language = None
          busy = True
          __case = "doing something"
      
      d_python = Developer()
      d_python.programing_language = "python"
      d_java = Developer()
      d_java.programing_language = "java"
      
      print(d_java.programing_language)
      print(d_python.programing_language)
      
      • 私有属性
        • 通过self.__变量名来声明私有属性
        • 通过实例._类名__变量名来访问私有属性

根据绑定目标和调用方式不同,方法可分为类方法, 静态方法, 实例方法

  • 类方法

    • cls 作为类方法的第一参数名

    • 仅供类调用的方法

    • 通过classmethod装饰器来声明一个类方法

    • 自定义类创建

      class Developer:
          programing_language = None
          busy = True
          __case = "doing something"
          def __init__(self, hairs):
              self.__hairs = hairs
      
          @classmethod
          def __new__(cls, *args, **kwargs):
              print("init class")
              return super().__new__(cls)
      
          @classmethod
          def get_case(cls):
              return cls.__case
      
  • 静态方法

    • 静态方法更像是普通函数,既不接受实例引用也不参与类处理。

    • 类可以直接调用的方法

    • 通过staticmethod装饰器装饰

    • 对一类抽象行为的归类

    • 使用静态方法,更多的原因是将类型作为第一作用域,或者为当前类型添加接口

      class MyMath:
      
          @staticmethod
          def add(a, b):
              return a + b
      
  • 实例方法

    • 顾名思义,实例方法与实例对象绑定,仅供实例调用的方法,将绑定的对象self作为第一参数。在实例引用调用方法时,无需显式传入第一实参self,而是由解释器自动完成。

总结:不论哪种方法,他们都保存在类型名字空间中,所以不能重名。装饰器和参数的差异,并不能改变同一名字空间字典中对同一主键重复赋值会覆盖前一次赋值的现实。

接口, 协议和抽象基类

  • 接口

    对象公开方法的子集, 让对象在系统中扮演特定的角色.

    list实现了增删改查的接口, 只要有一个接口没有实现那就不属于list
    tuple只提供了查的接口
    
  • 协议

    非正式的接口, 协议与继承没有关系, 一个类可能会实现多个接口, 从而让实例扮演多个角色

    list扮演者列表的角色, 但同时也是一个序列, 序列并不是一个实体类.
    
    • 协议的应用

      class MyDict(dict):
          def __iadd__(self, other):
              self.update(other)
              return self
      
          def __str__(self):
              return f"My Dict {self.items()}"
      
  • 抽象基类

    把客观事物封装成抽象的元类, 区分概念和实现.

    • 只要有@abc.abstractmethod装饰器的类就是抽象基类

      import abc
      class Mixin:
          def sign(self):
              pass
      
          def rank(self):
              pass
      
      class Gamer:
          @abc.abstractmethod
          def sign(self):
              pass
      
      
      class GoGamer(Mixin, Gamer):
          pass
      
      class Swimmer(Mixin, Gamer):
          pass
      
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值