在 C# 中 隐式 和 显式 实现接口有什么区别?
什么时候应该使用隐式,什么时候应该使用显式?
两者有什么优点和/或缺点吗?
Microsoft 的官方指南(来自第一版框架设计指南)指出 不建议使用显式实现 ,因为它会给代码带来意想不到的行为。
我认为这个指导方针在 IoC 之前的时代 非常有效,当你不把东西作为接口传递时。
任何人都可以触及这方面吗?
隐式 是当您通过类中的成员定义接口时。 显式 是当您在接口上的类中定义方法时。我知道这听起来令人困惑,但我的意思是:IList.CopyTo将隐式实现为:
IList.CopyTo
public void CopyTo(Array array, int index) { throw new NotImplementedException(); }
并明确为:
void ICollection.CopyTo(Array array, int index) { throw new NotImplementedException(); }
不同之处在于隐式实现允许您通过您创建的类访问接口,方法是将接口转换为该类和接口本身。显式实现允许您仅通过将接口转换为接口本身来访问接口。
MyClass myClass = new MyClass(); // Declared as concrete class myclass.CopyTo //invalid with explicit ((IList)myClass).CopyTo //valid with explicit.
我主要使用显式来保持实现干净,或者当我需要两个实现时。无论如何,我很少使用它。
我确信有更多理由使用/不使用其他人会发布的明确内容。