Python易错知识点

多继承以及MRO顺序

多继承指的是子类继承多个父类,可以通过三种方式访问父类的方法:

父类名.父类方法(self):这种方式容易造成父类方法被调用多次的问题(菱形继承问题),而且一旦父类名称发生变化,子类调用的地方都需要修改。

super(指定某个类名, self).父类方法():从指定类名的MRO下一级开始调用

super().父类方法():按照MRO顺序查找上级父类的方法。

「方法解析顺序」(Method Resolution Order简称MRO)

可以通过类名.__mro__属性查找出来当前类的调用顺序,其顺序由C3算法来决定,保证每一个类只调用一次。

单继承用哪种方式调用父类方法都可以,基本上无差别,但是建议super()的方式。

super()单继承只需要传父类参数,但是多继承必须传全部参数,可以使用多值参数。

super().__init__相对于类名.init,在单继承上用法基本无差

但在多继承上有区别,super方法能保证每个父类的方法只会执行一次,而使用类名的方法会导致方法被执行多次,具体看前面的输出结果

多继承时,使用super方法,对父类的传参数,应该是由于python中super的算法导致的原因,必须把参数全部传递,否则会报错

单继承时,使用super方法,则不能全部传递,只能传父类方法所需的参数,否则会报错

多继承时,相对于使用类名.__init__方法,要把每个父类全部写一遍, 而使用super方法,只需写一句话便执行了全部父类的方法,这也是为何多继承需要全部传参的一个原因

类属性和实例属性的区别

它们在定义和使用中有所区别,而最本质的区别是内存中保存的位置不同,
实例属性属于对象
类属性属于类

在Python中一切皆对象,类是一个特殊的对象即类对象,描述类的属性称为类属性,它属于类。类属性在内存中只有一份,所有实例对象公用,在__init__外部定义。

实例属性用来描述类创建出来的实例对象,需要通过对象来访问,在各自对象的内存中都保存一份,在__init__方法内部定义。

实例方法、静态方法和类方法

方法包括:实例方法、静态方法和类方法,三种方法在内存中都归属于类,区别在于调用方式不同。

实例方法由对象调用,至少一个self参数,self代表对象的引用。

类方法由类调用,至少一个cls参数,并且需要装饰器@classmethod修饰

静态方法由类调用,不需要参数,需要装饰器@staticmethod修饰

实例方法:由对象调用;至少一个self参数;执行实例方法时,自动将调用该方法的对象赋值给self;
类方法:由类调用; 至少一个cls参数;执行类方法时,自动将调用该方法的类赋值给cls;
静态方法:由类调用;无默认参数;

相同点:对于所有的方法而言,均属于类,所以 在内存中也只保存一份
不同点:方法调用者不同、调用方法时自动传入的参数不同。

property属性

通过使用property属性,能够简化调用者在获取数据的流程

装饰器 即:在方法上应用装饰器
类属性 即:在类中定义值为property对象的类属性

在类的实例方法上应用@property装饰器Python中的类有经典类和新式类,新式类的属性比经典类的属性丰富。( 如果类继object,那么该类是新式类 )

经典类中的属性只有一种访问方式,其对应被 @property 修饰的方法,即只能读取。

新式类中的属性有三种访问方式,并分别对应了三个被@property、@方法名.setter、@方法名.deleter修饰的方法,分别对应读取、修改和删除属性的方法。

类属性方式,创建值为property对象的类属性

当使用类属性的方式创建property属性时,经典类和新式类无区别

property()方法有四个参数

第一个参数是方法名,调用 对象.属性 时自动触发执行方法

第二个参数是方法名,调用 对象.属性 = XXX 时自动触发执行方法

第三个参数是方法名,调用 del 对象.属性 时自动触发执行方法

第四个参数是字符串,调用 对象.属性.doc ,此参数是该属性的描述信息

常见的魔方属性、方法

doc 表示类的描述信息

module 表示当前操作的对象在那个模块(main

class 表示当前操作的对象的类是什么

new 创建对象时为对象分配空间,在初始化方法__init__之前被调用

init 初始化方法,通过类创建对象时,自动触发执行,一般用来定义实例属性

del 当对象在内存中被释放时,自动触发执行

call 对象后面加括号,触发执行,例如对象()或者类名()()

dict 类或对象中的所有属性

str 在打印对象时,默认输出该方法的返回值(字符串)

面向对象设计

继承 - 是基于Python中的属性查找(如X.name)
多态 - 在X.method方法中,method的意义取决于X的类型
封装 - 方法和运算符实现行为,数据隐藏默认是一种惯例

with与“上下文管理器”

对于系统资源如文件、数据库连接、socket 而言,应用程序打开这些资源并执行完业务逻辑之后,必须做的一件事就是要关闭(断开)该资源。

比如 Python 程序打开一个文件,往文件中写内容,写完之后,就要关闭该文件,否则会出现什么情况呢?极端情况下会出现 “Too many open files” 的错误,因为系统允许你打开的最大文件数量是有限的。

同样,对于数据库,如果连接数过多而没有及时关闭的话,就可能会出现 “Can not connect to MySQL server Too many connections”,因为数据库连接是一种非常昂贵的资源,不可能无限制的被创建。

enter() 方法返回资源对象,这里就是你将要打开的那个文件对象,exit() 方法处理一些清除工作。

任何实现了 enter() 和 exit() 方法的对象都可称之为上下文管理器,上下文管理器对象可以使用 with 关键字。Python 提供了 with 语法用于简化资源操作的后续清除操作,是try/finally 的替代方法,实现原理建立在上下文管理器之上。

Python 还提供了一个 contextmanager 的装饰器,更进一步简化了上下文管理器的实现方式。通过 yield 将函数分割成两部分,yield 之前的语句在 enter 方法中执行,yield 之后的语句在 exit 方法中执行。紧跟在 yield 后面的值是函数的返回值。

exit(?)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值