C#继承的问题
class方法重载{staticvoidMain(string[]args){BaseClassson=newSonClass();Console.WriteLine(s...
class 方法重载
{
static void Main(string[] args)
{
BaseClass son = new SonClass();
Console.WriteLine(son.getName());
}
}
public class BaseClass
{
public string getName()
{
string name="我是基类的NAME!";
return name;
}
}
public class SonClass:BaseClass
{
public new string getName()
{
string name = "我是派生类的NAME!";
return name;
}
}
为什么代码打印出来的是“我是基类的NAME!”,这里不是运用的父类引用指向子类对象吗?真不知为什么?
我又在网上查了一些资料:
基类指针指向派生类的对象,我们知道这是多态调用;运行时基类指针根据运行时对象的类型,发现是派生类对象,所以首先到派生类的中去查找派生类的虚函数版本,发现派生类没有覆盖基类的虚函数,派生类的只是作了一个指向基类虚函数地址的一个指向,所以理所当然地去调用基类版本的虚函数。 重载是静态联编的,多态是动态联编的。进一步解释,重载与指针实际指向的对象类型无关,多态与指针实际指向的对象类型相关。 展开
{
static void Main(string[] args)
{
BaseClass son = new SonClass();
Console.WriteLine(son.getName());
}
}
public class BaseClass
{
public string getName()
{
string name="我是基类的NAME!";
return name;
}
}
public class SonClass:BaseClass
{
public new string getName()
{
string name = "我是派生类的NAME!";
return name;
}
}
为什么代码打印出来的是“我是基类的NAME!”,这里不是运用的父类引用指向子类对象吗?真不知为什么?
我又在网上查了一些资料:
基类指针指向派生类的对象,我们知道这是多态调用;运行时基类指针根据运行时对象的类型,发现是派生类对象,所以首先到派生类的中去查找派生类的虚函数版本,发现派生类没有覆盖基类的虚函数,派生类的只是作了一个指向基类虚函数地址的一个指向,所以理所当然地去调用基类版本的虚函数。 重载是静态联编的,多态是动态联编的。进一步解释,重载与指针实际指向的对象类型无关,多态与指针实际指向的对象类型相关。 展开
3个回答
展开全部
这样来说吧。对于一个确定的instance(实例),它由两部分构成。
1.instance的数据。
2.instance的方法。而instance的方法是由声明类型决定的。
BaseClass son=new SonClass();
在这里son被申明所属类型是BaseClass,因此C#将son实例解释为BaseClass类型的。
接着son.getName()。
C#将从两个类型中寻找方法。一个类型是申明类型,即BaseClass,另一个类型是实例类型,即SonClass。
而getName()在BaseClass和SonClass都有,那么就产生冲突了。
冲突的解决依赖关键字的判断,
1.new,在子类中new,那么意味着是隐藏父类方法。注意,隐藏父类方法的前提必须申明类型是SonClass。若申明类型是BaseClass,那么new将无用武之地。
2.override,在子类中override,那么意味着覆写父类方法。只要实例方法与父类方法冲突,一概只认子类方法。不管申明类型是BaseClass还是SonClass。
1.instance的数据。
2.instance的方法。而instance的方法是由声明类型决定的。
BaseClass son=new SonClass();
在这里son被申明所属类型是BaseClass,因此C#将son实例解释为BaseClass类型的。
接着son.getName()。
C#将从两个类型中寻找方法。一个类型是申明类型,即BaseClass,另一个类型是实例类型,即SonClass。
而getName()在BaseClass和SonClass都有,那么就产生冲突了。
冲突的解决依赖关键字的判断,
1.new,在子类中new,那么意味着是隐藏父类方法。注意,隐藏父类方法的前提必须申明类型是SonClass。若申明类型是BaseClass,那么new将无用武之地。
2.override,在子类中override,那么意味着覆写父类方法。只要实例方法与父类方法冲突,一概只认子类方法。不管申明类型是BaseClass还是SonClass。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我想你还是需要先了解一下override和new的区别再改改吧,下面是引自其它网友的回答:
如果你用override,则无论调用的是A类还是B类中的TEST(),系统都会找到它实质类的TEST();
如果是用的New,则可以通过类型转换调用到基类的TEST();
下面是override的情况:
A a = new A();
B b = new B();
A a1=new B();
a.Test();//调用A中Test();
b.Test();//调用B中Test();
a1.Test();//调用B中Test();系统会自动识别a1是B的实例
((A)b).Test();//与上面相同
下面是new的情况:
A a = new A();
B b = new B();
A a1=new B();
a.Test();//调用A中Test();
b.Test();//调用B中Test();
a1.Test();//调用A中Test();
((A)b).Test();//与上面相同
如果你用override,则无论调用的是A类还是B类中的TEST(),系统都会找到它实质类的TEST();
如果是用的New,则可以通过类型转换调用到基类的TEST();
下面是override的情况:
A a = new A();
B b = new B();
A a1=new B();
a.Test();//调用A中Test();
b.Test();//调用B中Test();
a1.Test();//调用B中Test();系统会自动识别a1是B的实例
((A)b).Test();//与上面相同
下面是new的情况:
A a = new A();
B b = new B();
A a1=new B();
a.Test();//调用A中Test();
b.Test();//调用B中Test();
a1.Test();//调用A中Test();
((A)b).Test();//与上面相同
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
诶吗呀,太复杂了
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询