深入探究 System.Collections 命名空间
1. System.Collections 命名空间概述
System.Collections 命名空间为对象集合提供了基本功能。它定义了接口、基类以及诸如字典、排序列表、队列和栈等集合的实现。基类还可扩展以创建专门的集合类型。不过,System.Collections.Specialized 命名空间包含了基于此命名空间的一组扩展集合类型,因此在创建自己的类型之前,可先查看该命名空间。
从设计上看,这些集合的设计初看有些奇怪。例如,“列表”为何要分为 IList 接口和 ArrayList 实现两部分,而且该命名空间还定义了许多看似不必要的接口,如 IEnumerable 和 IEnumerator。但实际上,此命名空间中集合类型的设计与其他容器库(如 C++ 中的 STL 和 JDK 1.2 中的 Java Collections 库)非常相似。通过将集合类型的接口(如“列表性”或“字典性”)与实际实现分离,我们只需对所使用的实际实现做最少的假设,而专注于完成工作所需的内容。例如,C# 的 foreach 构造会默默使用 IEnumerable 接口来获取一个继承自 IEnumerator 接口的对象。这意味着程序员可以创建一个自定义类型(如模拟一手牌),使其表现得像其他集合类一样。此外,迭代器(继承自 IEnumerator 的类型)可以是“智能”迭代器,知道如何遍历(或跳过)容器中的类型。这一切之所以可行,正是因为接口与实现分离,实现了解耦。
以下是该命名空间中一些重要类型的介绍:
2. ArrayList 类
ArrayList 类类似于数组,但可以根据需要增长或收缩。