It's basically the same reason why a bowl of bananas is not a bowl of fruits. If a bowl of bananas were a bowl of fruits, you could put an apple into the bowl, and it would no longer be a bowl of bananas.
As long as you only inspect the bowl, the conversion is harmless. But as soon as you start modifying it, the conversion becomes unsafe. This is the key point to bear in mind. (This is the precise reason why the immutable Scala collections actually allow the conversion, but the mutable collections prohibit it.)
Same with your example. If there was a conversion from Derived**
to Base**
, you could put a pointer to an apple were the type system promised only a pointer to a banana could exist. Boom!
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…