Python 序列构成的数组(内置序列类型概览)

内置序列类型概览

Python 标准库用C 实现了丰富的序列类型,列举如下。
容器序列
list、tuple 和collections.deque 这些序列能存放不同类型的数据。
扁平序列
str、bytes、bytearray、memoryview 和array.array,这类序列只能容纳一种类型。
容器序列存放的是它们所包含的任意类型的对象的引用,而扁平序列里存放的是值而不是
引用。换句话说,扁平序列其实是一段连续的内存空间。由此可见扁平序列其实更加紧
凑,但是它里面只能存放诸如字符、字节和数值这种基础类型。

序列类型还能按照能否被修改来分类。

可变序列
list、bytearray、array.array、collections.deque 和
memoryview。

不可变序列 tuple、str 和 bytes。
下图 显示了可变序列(MutableSequence)和不可变序列
(Sequence)的差异,同时也能看出前者从后者那里继承了一些方
法。虽然内置的序列类型并不是直接从 Sequence 和
MutableSequence 这两个抽象基类(Abstract Base Class,ABC)继承
而来的,但是了解这些基类可以帮助我们总结出那些完整的序列类型包
含了哪些功能。

image

上图这个 UML 类图列举了 collections.abc 中的几个类(超类
在左边,箭头从子类指向超类,斜体名称代表抽象类和抽象方法)通过记住这些类的共有特性,把可变与不可变序列或是容器与扁平序列
的概念融会贯通,在探索并学习新的序列类型时,你会更加得心应手。

最重要也最基础的序列类型应该就是列表(list)了。list 是一个可
变序列,并且能同时存放不同类型的元素。作为这本书的读者,我想你
应该对它很了解了,因此让我们直接开始讨论列表推导(list
comprehension)吧。列表推导是一种构建列表的方法,它异常强大,然
而由于相关的句法比较晦涩,人们往往不愿意去用它。掌握列表推导还
可以为我们打开生成器表达式(generator expression)的大门,后者具有
生成各种类型的元素并用它们来填充序列的功能。