python 新式类和旧式类
2016-06-13 09:40
405 查看
新式类和旧式类
python的新式类是2.2版本引进来的,我们可以将之前的类叫做经典类或者旧类。
为什么要在2.2中引进new style class呢?官方给的解释是:
为了统一类(class)和类型(type)。
在2.2之前,比如2.1版本中,类和类型是不同的,如a是ClassA的一个实例,那么a.__class__返回 ‘ class __main__.ClassA‘ ,type(a)返回总是<type 'instance'>。而引入新类后,比如ClassB是个新类,b是ClassB的实例,b.__class__和type(b)都是返回‘class '__main__.ClassB' ,这样就统一了。
引入新类后,还有其他的好处,比如更多的内置属性将会引入,描述符的引入,属性可以来计算等等。
为了向前兼容,默认情况下用户定义的类为经典类,新类需要继承自所有类的基类 object 或者继承自object的新类。
值得注意的地方是,虽然使用的是最新的python(2.7),但是一些特性不会在旧式类起作用。
所以,为了确保自己使用的是新式类,有以下方法:
把这个赋值语句放在类模块代码的最前面 __metaclass__ = type(前面有提过)。
自己的类都从内建类object直接或者间接地继承。
如果不需要兼容旧式类,旧版本的类,那么就保持都是新式类。
当然,在Python3里面,不存在这些问题了,因为所有的类都是object类的子类(隐式)。
代码示例:
class CC: #经典类
def __init__( self ):
pass
#新类,可以在这里加
__metaclass__ = type
class CCN(object): #新类,也可以直接继承至object类
def __init__( self ):
pass
c1 = CC()
c2 = CCN()
c1.__class__ # 输出-> <class __main__.CC at 0x0137BF10>
type(c1) # 输出-> <type 'instance'>
c2.__class__ # 输出-><class '__main__.CCN'>
type(c2) # 输出-><class '__main__.CCN'>
dir(c1)
[html] view
plaincopy
#输出 ->
[html] view
plaincopy
['__doc__', '__init__', '__module__']
dir(c2)
[html] view
plaincopy
输出 ->
[html] view
plaincopy
['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__
python的新式类是2.2版本引进来的,我们可以将之前的类叫做经典类或者旧类。
为什么要在2.2中引进new style class呢?官方给的解释是:
为了统一类(class)和类型(type)。
在2.2之前,比如2.1版本中,类和类型是不同的,如a是ClassA的一个实例,那么a.__class__返回 ‘ class __main__.ClassA‘ ,type(a)返回总是<type 'instance'>。而引入新类后,比如ClassB是个新类,b是ClassB的实例,b.__class__和type(b)都是返回‘class '__main__.ClassB' ,这样就统一了。
引入新类后,还有其他的好处,比如更多的内置属性将会引入,描述符的引入,属性可以来计算等等。
为了向前兼容,默认情况下用户定义的类为经典类,新类需要继承自所有类的基类 object 或者继承自object的新类。
值得注意的地方是,虽然使用的是最新的python(2.7),但是一些特性不会在旧式类起作用。
所以,为了确保自己使用的是新式类,有以下方法:
把这个赋值语句放在类模块代码的最前面 __metaclass__ = type(前面有提过)。
自己的类都从内建类object直接或者间接地继承。
如果不需要兼容旧式类,旧版本的类,那么就保持都是新式类。
当然,在Python3里面,不存在这些问题了,因为所有的类都是object类的子类(隐式)。
代码示例:
class CC: #经典类
def __init__( self ):
pass
#新类,可以在这里加
__metaclass__ = type
class CCN(object): #新类,也可以直接继承至object类
def __init__( self ):
pass
c1 = CC()
c2 = CCN()
c1.__class__ # 输出-> <class __main__.CC at 0x0137BF10>
type(c1) # 输出-> <type 'instance'>
c2.__class__ # 输出-><class '__main__.CCN'>
type(c2) # 输出-><class '__main__.CCN'>
dir(c1)
[html] view
plaincopy
#输出 ->
[html] view
plaincopy
['__doc__', '__init__', '__module__']
dir(c2)
[html] view
plaincopy
输出 ->
[html] view
plaincopy
['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__
相关文章推荐
- 一周stackoverflow热门问题选登:如何正确的理解python for循环中的else用法?
- python之sklearn
- 踩的python列表及for循环一个坑儿
- python之scipy
- python获取os.system的执行结果
- python---学习链接
- python之numpy
- python-登录-注册-修改密码
- python中class 的一行式构造器
- python入门简章
- Python处理带timezone的datetime类型
- 欢迎使用CSDN-markdown编辑器
- python中简单的类定义及调用方法
- 使用Python处理目录(一):打印目录下的文件名
- Python __file__与argv[0]
- python的函数定义方式
- Python中进行布尔类型处理时的特殊点
- numpy中的ndarray方法和属性
- python的print函数的一些功能
- Python环境安装