以下是个人理解.
若定义委托:
delegate Dog DoSomething(Dog d);
其中 Dog 的父类是 Animal, Dog 的子类是 ZombieDog
- 逆变使得委托实例上的目标方法可以接收更抽象的参数, 比如 Animal.
- 协变使得委托实例上的返回类型可以更加具体, 比如 ZombieDog.
为什么逆变是这样的呢…?
- 当我们调用委托实例时, 我们将传递给他一个参数a, 类型为A, 由于委托的参数类型为Dog, 所以 A >= Dog (指 A is Dog).
- 假设委托实例引用的目标方法的参数类型为B, 应该有 A >= B, 那么显而易见地 B <= Dog, 所以参数类型B就可以是Animal.
为什么协变是这样的呢…?
- 当我们调用委托实例时, 假设我们期望接收一个返回值c, 类型为C, 由于委托的返回类型为Dog, 所以 C <= Dog.
- 假设委托实例引用的目标方法的返回类型为D, 应该有 C <= D, 那么显而易见地 D >= Dog, 所以返回类型D就可以是ZombieDog.
理解了多态这个还是好理解的…只是’逆变’和’协变’这两个词听起来看起来都像是某个魔咒…