博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python 面向对象oop
阅读量:5104 次
发布时间:2019-06-13

本文共 2962 字,大约阅读时间需要 9 分钟。

1 oop 对象世界观  -- oop是目前人类认知最接近实际生活的语言

  • 一切事务皆对象
  • 对象有运动规律和内部状态
  • 对象之间可以相互调用

2.面向对象

  • 唯一性:对象具有唯一性,不存在两个相同的对象,除非他们是同一个对象
  • 可以分类性 : 对象可以分类

3.oop 分类

  • 封装
  • 继承
  • 多态

具体类:

结构

  classs 类名:

    类体

  • 创建对象使用类名(__init__ 函数除第一个参数外的参数列表)
  • 创建对象的时候 实际执行了 __init__函数, __init__ 并不会创建对象,但会初始化对象
  • 当使用对象来调用方法的时候,第一个参数会自动的传入(默认是self,这个self这四个字母可以替换成任意字符,但位置必须是第一个)

作用域

  • 类的直接下级作用域 叫做类变量
  • 关联到实例的变量 叫做实例变量

例子:

1 class E:2     NAME = 'E' # 类的直接下级作用域 叫做类变量3     4     def __init__(self, name):5         self.name = name  # 关联到实例的变量 叫做实例变量
  • 类变量对类和实例都可见
  • 所有实例共享类变量
  • Python 可动态的给对象增减属性,当给实例的类变量赋值时,相当于动态的给这个实例增加了一个属性,覆盖了类变量

 

属性的查找顺序

  • __dict__  :当通过对象动态增加属性的时候,如果存在此属性,会覆盖原属性,不存在会存放到对象.__dict__中。

  • __class__ : 如果通过类名.类属性方式给类属性重新赋值,原类属性会被覆盖

  --------------------------------------------------- 只需要对象.__dict__ 来看其内容能分辨-----------------------------------------------------------------------------  

类装饰器通常用于给类增加属性-- 方法都是类级的

类方法/静态方法

方法的定义都是类级的,但是有的方法使用实例调用,有的方法使用类来调用

class I:    def print(self):        print('instance method')        @classmethod  # 当一个方法,被classmethod装饰的时候, 第一个参数会变成类本身, 这样的方法叫类方法    def class_print(cls):        print(id(cls))        print('class method')        @staticmethod # 当一个方法, 被staticmethod装饰的时候,不会自动传递第一个参数, 这样的方法叫静态方法    def static_print():        print('static method')            def xxx_print():        print('this is a function')

实例方法只能由实例调用

类方法:类方法可以被实例使用,并且被实例使用时,传入的第一个参数还是类

访问控制

 

class Door:    def __init__(self, number, status):        self.number = number        self.__status = status  # 双下划线开始, 非双下划綫结尾的都是私有的, 在类外部无法访问        def open(self): # 方法        self.__status = 'opening'            def close(self):        self.__status = 'closed'        def status(self):        return self.__status        def __set_number(self, number): # 双下滑先开始, 非双下划线结尾的方法也是私有方法        self.number = number

所有双下划线开始,非双下划线结尾的成员,都是私有成员

私有成员在类外部无法访问

Python的私有成员是通过改名实现的,_类名 + 带双下划綫的属性 在__dict__ 中会有标识(python中没有真正的私有成员,但这可以忽略不计)

部分代码中 用单下划线标注的变量可以理解为内部变量,不希望在外部继续调用(其实外部可以调用),解释器不不做任何处理

双下划线开始,非双下划线结尾的方法是私有方法。

如果用 @property  装饰器会把一个仅有self参数的函数,变成一个属性, 属性的值,为方法的返回值

class Door:    def __init__(self, status):        self.__status = status  # 双下划线开始, 非双下划綫结尾的都是私有的, 在类外部无法访问           @property    # property 装饰器会把一个仅有self参数的函数,变成一个属性, 属性的值,为方法的返回值    def status(self):        return self.__status
d = Door('opening')print(d.status) status 为 Door 中 status方法

类的继承

  • 在类名后加括号 括号中是继承列表, 称之为父类或者基类或者超类- python中不建议多继承
  • 继承一个明显的好处就是可以获取父类的属性和方法,深层次继承会比较乱
  • 凡是公有的都能继承
  • 凡是私有的都不能继承
  • 原来是什么,继承过来还是什么
  • 当子类和父类有同名成员的时候, 子类的成员会覆盖父类的同名成员
  • super(父类, self).print() # 代理 TYPE 的父类的方法, 并且使用 obj 绑定 第一个参数 指定调用谁的直接父类, 第二个参数指定当调用时,传递什么作为方法的第一个参数

  • 当父类含有一个带参数的初始化方法的时候,子类一定需要一个初始化方法,并且在初始化方法中调用父类的初始化方法
    class Base:    def __init__(self, a, b):        self.__a = a        self.__b = b        def sum(self):        return self.__a + self.__b
    class Sub(Base):    def __init__(self, a, b, c):        self.c = c#         self.__a = a#         self.__b = b        super().__init__(a, b)
  • super 对象只能获取类的属性

 

转载于:https://www.cnblogs.com/lcmemo/p/6424389.html

你可能感兴趣的文章
bzoj3944 Sum
查看>>
后缀表达式/逆波兰表达式
查看>>
如何处理Win10电脑黑屏后出现代码0xc0000225的错误?
查看>>
局域网内手机访问电脑网站注意几点
查看>>
IT项目经验和难点分享
查看>>
TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort()方法如何比较元素?...
查看>>
Redis系列--内存淘汰机制(含单机版内存优化建议)
查看>>
最小二乘法
查看>>
iptables端口转发
查看>>
Android 8 AudioPolicy 分析
查看>>
Java Web开发后端常用技术汇总
查看>>
How to use jQuery countdown plugin
查看>>
富文本常用封装(NSAttributedString浅析)
查看>>
c++ STL
查看>>
json数据在前端(javascript)和后端(php)转换
查看>>
[Serializable]的应用--注册码的生成,加密和验证
查看>>
Groovy中那些神奇注解之ToString
查看>>
宇宙第一开发工具:vs2019 开发Python
查看>>
Tomcat Https配置
查看>>
待续--mysql中key 、primary key 、unique key 与index区别
查看>>