C#的IDictionary和Dictionary有什么区别?为什么应该优先使用接口?

来源:这里教程网 时间:2026-02-21 17:30:23 作者:

IDictionaryDictionary 是 C# 中用于存储键值对的两个相关但不同的类型,它们之间的主要区别在于:一个是接口,另一个是具体类。

1. IDictionary 是接口,Dictionary 是实现类

IDictionary 是一个接口,定义了操作键值对的基本方法和属性,比如 Add、Remove、ContainsKey、this[T] 索引器等。它不包含具体实现,只规定“能做什么”。

Dictionary 是 .NET 提供的一个具体类,实现了 IDictionary 接口(更准确地说,是实现了 IDictionary),提供了哈希表的底层实现,真正“做了什么”。

简单来说:

IDictionary(或泛型版本 IDictionary) → 合同(契约) Dictionary → 具体执行者

2. 为什么应该优先使用接口?

在声明变量、参数或返回类型时,推荐优先使用 IDictionary 而不是 Dictionary,原因如下:

降低耦合性:依赖接口而非具体实现,可以让代码更容易替换底层实现。例如,未来你可能想用自定义字典、只读字典或线程安全字典替代 Dictionary,只要它们也实现 IDictionary 接口,调用方代码无需修改。 提高可测试性:在单元测试中,可以轻松用模拟对象(mock)代替真实 Dictionary,只要它实现 IDictionary 接口,便于隔离测试。 遵循面向对象设计原则:符合“针对接口编程,而不是针对实现编程”的设计思想(出自《设计模式》),使代码更灵活、可维护。 支持多态:方法接收 IDictionary 参数时,可以传入任何实现该接口的对象,包括第三方库提供的字典类型。

3. 实际代码示例

不推荐写法(依赖具体类):

public void ProcessUsers(Dictionary<string, User> users) { ... }

推荐写法(依赖接口):

public void ProcessUsers(IDictionary<string, User> users) { ... }

这样无论是 Dictionary、SortedDictionary,还是只读包装字典,都可以传入。

4. 注意泛型与非泛型接口

尽量使用泛型版本 IDictionary,避免使用非泛型的 IDictionary(来自 System.Collections),因为后者操作的是 object 类型,会有装箱拆箱问题,且缺乏类型安全。

Dictionary 同时实现了:

IDictionary IDictionary(非泛型)

开发中应优先选择泛型接口以获得更好的性能和类型检查。

基本上就这些。优先使用接口是一种良好的编程习惯,让代码更健壮、更易扩展。虽然 Dictionary 是最常用的实现,但对外暴露时,用 IDictionary 更合适。

相关推荐