public class Base
{
public virtual void test()
{
Console.WriteLine("这是父类方法!"); }
} public class Class1:Base
{
public override void test()
{
Console.WriteLine("这是CLASS1方法");
//base.test();
}
} public class Class2 : Base
{
public new void test()
{
Console.WriteLine("这是Class2方法!");
//base.test();
}
} Base b = new Base();
Class1 class1 = new Class1();
Class2 class2 = new Class2();
b.test(); //输出 这是父类方法
class1.test(); //输出 这是CLASS1方法
class2.test(); //输出 这个 Class2 方法
---上面的结果 说明 override 和 new 有达到了 重写的目的
参考 msdn
Base[] b = new Base[2];
b[0] = new Class1();
b[1] = new Class2();
foreach (Base bb in b)
{
bb.test();
}
输出结果是 : 这是CLASS1方法
这是父类方法 //主要 是这里不明白,为什么 又是调用的父类方法呢 ,明明 实列化 的new class2()
请高手释疑???
{
public virtual void test()
{
Console.WriteLine("这是父类方法!"); }
} public class Class1:Base
{
public override void test()
{
Console.WriteLine("这是CLASS1方法");
//base.test();
}
} public class Class2 : Base
{
public new void test()
{
Console.WriteLine("这是Class2方法!");
//base.test();
}
} Base b = new Base();
Class1 class1 = new Class1();
Class2 class2 = new Class2();
b.test(); //输出 这是父类方法
class1.test(); //输出 这是CLASS1方法
class2.test(); //输出 这个 Class2 方法
---上面的结果 说明 override 和 new 有达到了 重写的目的
参考 msdn
Base[] b = new Base[2];
b[0] = new Class1();
b[1] = new Class2();
foreach (Base bb in b)
{
bb.test();
}
输出结果是 : 这是CLASS1方法
这是父类方法 //主要 是这里不明白,为什么 又是调用的父类方法呢 ,明明 实列化 的new class2()
请高手释疑???
解决方案 »
- 关于一个自定义的MD5加密的问题
- Cache存储TreeView,并取出的问题
- [感悟]网站与数据
- sql server,数据库,access问题,.net
- C#的C/S结构问题
- 在一张页面中,放了两个DataGrid,第二张表分页时,第一张也跟着分页了?
- 给个连接数据库的语句吧,VS2003+SqlServer2000+ASP.net
- 求助:路径问题.达人帮忙!!!
- 再开贴高分求高手解决,关闭新窗口时刷新老窗体中的DataGrid。
- 能不能帮我看看这段代码,困惑好长时间了
- <html>
- gridview中我创建了CheckBoxField ,但不可选,请问怎样设置才能在页面修改这个CheckBoxField
---
因为这句什么,能否说清楚点
当定义为new,Base[] b 引用的是本身的方法
overwrite ----- 执行实例类型方法
而public override void test()是重写父类public virtual void test()方法.当new class1()这个对象的时候,不论如何,都会先执行重写父类中test()方法的语句.
new class2()的时候不会执行public new void test()这句.因为你并没有调用真正意义上的class2()对象.
而是一个base对象而已...最起码编译译器的开发人员应该是这么理解的...所以你问的问题只有一个答案,就是你这么写编译器不会先覆盖父类中的方法,如果你一定要问为什么..那么就要到微软去把那个开发C#的人拖出来打一顿.