1.经典类与新式类

在了解Python的类与类型前,需要对Python的经典类(classic classes)与新式类(new-style classes)有个简单的概念。

在Python 2.x及以前的版本中,由任意内置类型派生出的类(只要一个内置类型位于类树的某个位置),都属于“新式类”,都会获得所有“新式类”的特性;反之,即不由任意内置类型派生出的类,则称之为“经典类”。

“新式类”和“经典类”的区分在Python 3.x之后就已经不存在,在Python 3.x之后的版本,因为所有的类都派生自内置类型object(即使没有显示的继承object类型),即所有的类都是“新式类”。

官方文档 https://www.python.org/doc/newstyle/

2.类的实例与对象

在很多语言中,类的实例与类的对象,只是同一事物的不同名称。而在Python中,类的对象与类的实例,是完全不同的概念。在本文中,所称的类对象,是指由class代码块执行后创建的类对象,而类的实例则是由类对象所创建的实例。这里只做简单提及,便于下文理解,要更深入的理解这个概念,可以参考“python一切皆对象”的相关知识。

3.类实例的类与类型

尝试分别在Python 2.x 和 3.x 版本中运行如下代码:

class A():pass
class B():pass a = A()
b = B() if __name__ == '__main__':
print(type(a))
print(type(b))
print(type(a) == type(b))
print(a.__class__)
print(b.__class__)
print(a.__class__ == b.__class__)

Python 2.6.9 及 2.7.10 的运行结果:

在Python 2.x及以前的版本,所有经典类的实例都是“instance”(实例类型)。所以比较经典类实例的类型(type)毫无意义,因为所有的经典类实例都是instance类型,比较的结果通常为True。更多情况下需要比较经典类实例的__class__属性来获得我们想要的结果(或使用isinstance函数)。

Python 3.5.1 运行结果

在Python 3.x及之后的版本,类和类型已经合并。类实例的类型是这个实例所创建自的类(通常是和类实例的__class__相同),而不再是Python 2.x版本中的“instance”实例类型。

需要注意的是,在Python 2.x版本中,“经典类的实例都是instance类型”,这个结论只适用于经典类。对新式类和内置类型的实例,它们的类型要更加明确。

修改之前的代码验证上述观点,尝试让class a 和 class b 显示继承自object,成为“新式类”。

class A(object):pass
class B(object):pass a = A()
b = B() if __name__ == '__main__':
print(type(a))
print(type(b))
print(type(a) == type(b))
print(a.__class__)
print(b.__class__)
print(a.__class__ == b.__class__)

Python 2.7.10 运行结果:

代码运行结果和Python 3.x是完全相同的,可以看出Python 2.x 新式类实例的类型就是这个实例所创建自的类。同时进一步印证在Python 3.x中所有的类都是新式类(显示或隐式继承自object类)。

接着对内置类型进行验证,尝试运行以下代码

print(type([1, 2, 3]))

Python 2.7.10运行结果:

可以看出,内置类型实例的类型,也是同新式类一样,是这个实例所创建自的类。在示例代码中,我们创建了一个list,所以实例的类型为list类型。

4.类的类型

如果说,一个类实例的类型是创建它的类(python 3.x),那一个类的类型又是什么???

继续使用代码尝试验证:

class A():pass
class B():pass if __name__ == '__main__':
print(type(A))
print(type(B))
print(type(A) == type(B))

Python 2.7.10 运行结果:

从运行结果我们可以看出,在Python 2.x 中,经典类的类型都是classobj。type(A) == type(B)结果为True,说明它们是同一种类型。

Python 3.5.1运行结果:

从运行结果我们可以看出,所有的类型都是type类,再次印证在Python 3.x 类与类型已经完全合并,类即类型,类型即类。

再次修改代码,使 class A 和 B 显式继承自 object,成为新式类,再在Python 2.7.10 下运行查看结果:

运行结果显而易见,和Python 3.x 是一样的,因为它们都是新式类。

注:在运行结果中,Python 2.x 显示为 <type 'type'>,而 Python 3.x 显示为<class 'type'>, 仅是显示方法不同,可以理解为等价,因为在Python 3.x类即类型。

参考官方文档:https://docs.python.org/3/library/stdtypes.html#bltin-type-objects

Type objects represent the various object types. An object’s type is accessed by the built-in function type(). There are no special operations on types. The standard module types defines names for all standard built-in types.

Types are written like this: <class 'int'>.

再来进行一个有趣的尝试:

print(type(type))

在python 2.x 和 3.x 运行结果都是一样的,type类型本身也是类(新式类和内置类型的类与类型已经合并),它自己也是type类型。

5.类是Type类的实例

有上文的测试可以得知:所有的类型都是type类。从另一个角度理解,类就是type类的实例,所有的新式类,都是由type类实例化创建而来,并且显式或隐式继承自object。

type([1, 2, 3])

得到运行结果:<class 'list'>,说明[1, 2, 3]这个list是list类的实例。

同样的

type(list)

得到运行结果:<class 'type'>,也可以说明list这个类是type类的实例。

通过调用__class__属性可以得到同样的结果:

list.__class__
[1, 2, 3].__class__

说明类对象是type类的实例。

6.有趣的循环

前文提到,在Python 3.x 中,所有的类都显式或隐式的派生自object类,type类也不例外。类型自身派生自object类,而object类派生自type,二者组成了一个循环的关系。

通过以下代码来验证

isinstance(object, type)
isinstance(type, object)

运行结果:

从运行结果可以看出object是type类型, type类型也是object类型

Python的类与类型的更多相关文章

  1. python中对象、类型和元类之间的关系

    在python中对象.类型和元类构成了一个微妙的世界. 他们有在这个世界里和平共处,相辅相成.它们遵循着几条亘古不变的定律: 1.python中无处不对象 2.所有对象都有三种特性:id.类型.值 3 ...

  2. 第7.28节 《Python类、类型、协议》章节总结

    本章详细介绍了Python协议.多态与"鸭子类型".类.类实例变量.类变量.实例方法.类方法.静态方法.类继承.抽象类.property函数和@property装饰器定义属性访问方 ...

  3. Python中对象、类型、元类之间的关系

    Python里的对象.类型和元类的关系很微妙也很有意思. 1989年圣诞节期间,上帝很无聊,于是创造了一个世界. 对象 在这个世界的运转有几条定律. 1.一切都是对象 对象(object)是这个世界的 ...

  4. Python 中的枚举类型~转

    Python 中的枚举类型 摘要: 枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表示某些特定的有限集合,例如星期.月份.状态等. 枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表 ...

  5. python(6)-类

    面向对象编程是一种编程方式,此编程方式的落地需要使用 "类" 和 "对象" 来实现,所以,面向对象编程其实就是对 "类" 和 "对 ...

  6. 从C#到Python —— 4 类及面向对象

    http://www.cnblogs.com/yanxy/archive/2010/04/04/c2p_4.html 如果你熟悉C#,那么对类(Class)和面向对象(Object Oriented) ...

  7. Python type类具体的三大分类:metaclasses,classes,instance

    Python type类视角中的对象体系需要我们不断的学习,其中我们使用的时候需要注意.下面我们就看看如何才能更好的运用Python type类.下面的文章希望大家有所收获. 在单纯的Python t ...

  8. python元类分析

    刚開始接触到Python新式类中的元类的概念的时候非常是纠结了下..不知道这是个啥东西... 用下面几个定义来说明吧: (1)Python中,类也是对象..仅仅只是这样的对象比較的特殊,他用于创建别的 ...

  9. Python基础-类

    Python基础-类 @(Python)[python, python基础] 写在前面 如非特别说明,下文均基于Python3 摘要 本文重点讲述如何创建和使用Python类,绑定方法与非绑定方法的区 ...

随机推荐

  1. 【NOIP2012提高组】同余方程

    https://www.luogu.org/problem/show?pid=1082 方程可化为ax+by=1. 用扩展欧几里得算法得到ax'+by'=gcd(a,b)的一组解后,可得x=x'/gc ...

  2. Python爬虫(十四)_BeautifulSoup4 解析器

    CSS选择器:BeautifulSoup4 和lxml一样,Beautiful Soup也是一个HTML/XML的解析器,主要的功能也是如何解析和提取HTML/XML数据. lxml只会局部遍历,而B ...

  3. NDK开发过程自认为好的一些参考资料

    虽然NDK开发时间很短, 但也接触了一些自认为还不错的资料, 记录下来. 一.首先就说官方文档吧 网上资料好多过时了, 并且有点参差不齐. 所以看官方文档还是很有必要的,我根据我的需求整理了两个的链接 ...

  4. 面向矩阵的numpy入门笔记

    我先声明我学numpy的目的:在python中使用矩阵(我需要在机器学习中使用矩阵),所以我的目的很明确,矩阵: 矩阵在numpy中叫ndarray(The N-dimensional array), ...

  5. [UWP]了解TypeConverter

    1. 前言 TypeConverter是XAML解释器的幕后功臣,它做了大量工作,从WPF诞生以来,几乎每一次XAML的运作都有它的参与.虽然UWP中TypeConverter已经彻彻底底退居幕后,连 ...

  6. python集合增删改查,深拷贝浅拷贝

    集合 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. 关系 ...

  7. JAVA9模块化详解(二)——模块的使用

    JAVA9模块化详解(二)--模块的使用 二.模块的使用 各自的模块可以在模块工件中定义,要么就是在编译期或者运行期嵌入的环境中.为了提供可靠的配置和强健的封装性,在分块的模块系统中利用他们,必须确定 ...

  8. python_web----------数据可视化从0到1的过程

    一.数据可视化项目配置 1. django + Echarts 2. 服务器(linux:Ubuntu 17.04 (GNU/Linux 4.10.0-40-generic x86_64)) 3. I ...

  9. 【java】method.invoke(方法底层所属对象/null,new Object[]{实际参数})

    反射调方法时无论是静态/非静态,固定/可变参数,都有Object对象数组对参数进行包装. package com.tn.clas; import java.lang.reflect.Method; i ...

  10. iOS知识点集合--更改(2)

    3.nsmutablearray *a 如果直接赋值 a = @[@"d",@""]; 这个时候a 是不可变的 字典也是如此 2.如果接口调用错误的话 打印re ...