IDictionary是接口,Dictionary是其具体实现类。优先使用IDictionary可降低耦合、提升可测试性与扩展性,符合面向对象设计原则,推荐在参数、返回值中使用泛型IDictionary而非具体Dictionary类型。

IDictionary 和 Dictionary 是 C# 中用于存储键值对的两个相关但不同的类型,它们之间的主要区别在于:一个是接口,另一个是具体类。
1. IDictionary 是接口,Dictionary 是实现类
IDictionary 是一个接口,定义了操作键值对的基本方法和属性,比如 Add、Remove、ContainsKey、this[T] 索引器等。它不包含具体实现,只规定“能做什么”。
Dictionary
简单来说:
- IDictionary(或泛型版本 IDictionary
) → 合同(契约) - Dictionary
→ 具体执行者
2. 为什么应该优先使用接口?
在声明变量、参数或返回类型时,推荐优先使用 IDictionary
- 降低耦合性:依赖接口而非具体实现,可以让代码更容易替换底层实现。例如,未来你可能想用自定义字典、只读字典或线程安全字典替代 Dictionary,只要它们也实现 IDictionary 接口,调用方代码无需修改。
- 提高可测试性:在单元测试中,可以轻松用模拟对象(mock)代替真实 Dictionary,只要它实现 IDictionary 接口,便于隔离测试。
- 遵循面向对象设计原则:符合“针对接口编程,而不是针对实现编程”的设计思想(出自《设计模式》),使代码更灵活、可维护。
- 支持多态:方法接收 IDictionary 参数时,可以传入任何实现该接口的对象,包括第三方库提供的字典类型。
3. 实际代码示例
不推荐写法(依赖具体类):
public void ProcessUsers(Dictionaryusers) { ... }
推荐写法(依赖接口):
public void ProcessUsers(IDictionaryusers) { ... }
这样无论是 Dictionary、SortedDictionary,还是只读包装字典,都可以传入。
4. 注意泛型与非泛型接口
尽量使用泛型版本 IDictionary
Dictionary
- IDictionary
- IDictionary(非泛型)
开发中应优先选择泛型接口以获得更好的性能和类型检查。
基本上就这些。优先使用接口是一种良好的编程习惯,让代码更健壮、更易扩展。虽然 Dictionary 是最常用的实现,但对外暴露时,用 IDictionary 更合适。










