看看ReadOnlyCollection类的规范,它确实实现了IList接口,对。
IList 接口有 Add/Update/Read 方法,我们称之为接口的前置条件。如果我有 IList,我应该能够在我的应用程序中的任何地方执行所有此类操作。
但是,如果我在代码中的某处返回 ReadOnlyCollection 并尝试调用 .Add(...) 方法呢?它抛出一个 NotSupportedException。你认为这是一个糟糕设计的好例子吗?另外,这个类是否违反了Liskov 替换原则?
微软为何采用这种方式?让这个 ReadOnlyCollection 只实现 IEnumerable 接口(顺便说一句,它已经是只读的)是否应该更容易(更好)?