Python新式类和经典类的区别
来源:互联网 发布:网络宣传的好处 编辑:程序博客网 时间:2024/05/01 10:01
从Python2.2开始,Python 引入了 new style class(新式类)
新式类跟经典类的差别主要是以下几点:
新式类对象可以直接通过__class__属性获取自身类型:type
# -*- coding:utf-8 -*- class E: #经典类 pass class E1(object): #新式类 pass e = E()print "经典类"print eprint type(e)print e.__class__print "新式类"e1 = E1()print e1print e1.__class__print type(e1)
经典类<__main__.E instance at 0x0000000002250B08><type 'instance'>__main__.E新式类<__main__.E1 object at 0x0000000002248710><class '__main__.E1'><class '__main__.E1'>
我使用的是python 2.7。
E1是定义的新式类。那么输输出e1的时候,不论是type(e1),还是e1.__class__都是输出的<class '__main__.E1'>。
2. 继承搜索的顺序发生了改变,经典类多继承属性搜索顺序: 先深入继承树左侧,再返回,开始找右侧;新式类多继承属性搜索顺序: 先水平搜索,然后再向上移动
# -*- coding:utf-8 -*- class A(object): """新式类 作为所有类的基类 """ def foo(self): print "class A" class A1(): """经典类 作为所有类的基类 """ def foo(self): print "class A1" class C(A): passclass C1(A1): passclass D(A): def foo(self): print "class D" class D1(A1): def foo(self): print "class D1" class E(C, D): passclass E1(C1, D1): passe = E()e.foo() e1 = E1()e1.foo()
输出
class Dclass A1
因为A新式类,对于继承A类都是新式类,首先要查找类E中是否有foo(),如果没有则按顺序查找C->D->A。它是一种广度优先查找方式。
因为A1经典类,对于继承A1类都是经典类,首先要查找类E1中是否有foo(),如果没有则按顺序查找C1->A1->D1。它是一种深度优先查找方式。
3. 新式类增加了__slots__内置属性, 可以把实例属性的种类锁定到__slots__规定的范围之中。
比如只允许对A实例添加name和age属性:
# -*- coding:utf-8 -*- class A(object): __slots__ = ('name', 'age') class A1(): __slots__ = ('name', 'age') a1 = A1()a = A()a1.name1 = "a1"a.name1 = "a"
A是新式类添加了__slots__ 属性,所以只允许添加 name age
A1经典类__slots__ 属性没用,
Traceback (most recent call last): File "t.py", line 13, in <module> a.name1 = "a"AttributeError: 'A' object has no attribute 'name1'
所以a.name是会出错的
通常每一个实例都会有一个__dict__属性,用来记录实例中所有的属性和方法,也是通过这个字典,可以让实例绑定任意的属性
而__slots__属性作用就是,当类C有比较少的变量,而且拥有__slots__属性时,
类C的实例 就没有__dict__属性,而是把变量的值存在一个固定的地方。如果试图访问一个__slots__中没有
的属性,实例就会报错。这样操作有什么好处呢?__slots__属性虽然令实例失去了绑定任意属性的便利,
但是因为每一个实例没有__dict__属性,却能有效节省每一个实例的内存消耗,有利于生成小而精
干的实例。
4. 新式类增加了__getattribute__方法
class A(object): def __getattribute__(self, *args, **kwargs): print "A.__getattribute__"class A1(): def __getattribute__(self, *args, **kwargs): print "A1.__getattribute__"a1 = A1()a = A()a.testprint "========="a1.test
A.__getattribute__=========Traceback (most recent call last): File "t.py", line 18, in <module> a1.testAttributeError: A1 instance has no attribute 'test'
可以看出A是新式类,每次通过实例访问属性,都会经过__getattribute__函数,
A1不会调用__getattribute__所以出错了
Python 2.x中默认都是经典类,只有显式继承了object才是新式类
Python 3.x中默认都是新式类,不必显式的继承object
- Python新式类和经典类的区别
- Python经典类和新式类的区别
- Python新式类和经典类的区别
- Python中新式类和经典类的区别
- python新式类和经典类的区别
- python新式类和经典类的区别?
- Python新式类和经典类的区别
- python笔记: 经典类和新式类的区别
- Python新式类和经典类的区别
- Python新式类与经典类(旧式类)的区别
- Python新式类与经典类(旧式类)的区别
- Python 新式类与经典类的区别
- Python高级编程——15.新式类和经典类的区别
- Python新式类和经典类
- python 经典类和新式类
- python 新式类 和 旧式类区别
- Python新式类和旧式类的区别
- Python新式类和旧式类的区别
- 如何远程访问mysql数据库
- UCI命令系统
- 分析ReentrantLock之lockInterruptibly
- 欢迎使用CSDN-markdown编辑器
- 浮点型转string
- Python新式类和经典类的区别
- JUnit源码与设计模式欣赏——JUnit学习(三)
- WPF中Tooltip使用技巧总结
- C++中以固定分隔符分割CString字符串
- 欢迎使用CSDN-markdown编辑器
- unity 插件 iTween简单用法
- Storm-0.9.0.1安装部署 指导
- UE3到UE4过渡的指导
- UILable写出类似Cell的UITableViewCellStyleSubtitle状态下效果