这将被称为“扩大转换”,因为您在引用类型方面变得不那么具体,您正在扩大潜在类型的集合。当您有Employee
引用时,您知道您可以使用特定于该类的任何功能,当您Person
引用同一对象时,您只知道您可以使用Person
该类中包含的功能。如果你想在你的引用中使用Employee
特定的功能,你prs
首先必须将你的引用转换回一个Employee
引用,如果prs
它实际上不是类型Employee
(也许它Customer
也是继承自的类型Person
),那么你会得到一个InvalidCastException
.
当您处理参考时,该SurName
属性不会消失。Person
您只是无法访问它,因为它不包含在Person
类中。基本上,如果您有基类类型的引用,您将只能访问包含在基类中的属性/方法。它实际上是一个并不重要Employee
,你有一个Person
引用,所以对象会被相应地处理。
转换在您的示例中没有用。当您尝试以通用方式处理许多子类时,转换很有用。例如,我可能有一Person
堂课。除此之外,我还有从它继承的Employee
、Customer
和类。Consultant
现在假设我有一个Store
对象,我想做一些事情,比如获取Person
当前在商店中的每个人的名字。解决此问题的最简单方法是List<Person>
与商店中的所有人一起进行。因为Employee
, Customer
, 和Consultant
所有继承自我Person
可以做
peopleInMyStore.Add(MyEmployee);
peopleInMyStore.Add(MyCustomer);
peopleInMyStore.Add(MyConsultant);
然后稍后我可以做类似的事情;
foreach (Person p in peopleInMyStore)
{
Console.WriteLine(p.Name);
}
这个概念被称为“多态性”,可以在这里阅读http://en.wikipedia.org/wiki/Polymorphism_(computer_science)
我的示例是人为的,但这是您使用继承的主要原因之一。给你一个真实的例子,我有一些测试代码,其中我有一个名为的类ApiTestSuite
,然后我有大约十几个类都继承自它的形式SpecificApiTestSuite
。该项目构建为命令行可执行文件,您使用 api 参数 (api=specificApiName) 调用它,然后我可以执行以下操作;
ApiTestSuite tests;
if (args[0] == "api1")
tests = new Api1TestSuite();
else
tests = new Api2TestSuite();
tests.RunTests();