虚方法和重写方法.pptVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
虚方法和重写方法

虚方法和重写方法 虚方法 当类中的方法声明前加上了virtual修饰符,我们称之为虚方法,反之为非虚。使用了virtual修饰符后,不允许再有 static,abstract,或override修饰符。 若希望或预料到基类的这个方法在将来的派生类中会被重写(override ),则此方法必须被声明为 virtual。 虚方法的定义形式 virtual 修饰符 返回的数据类型 方法名(参数表) { 方法体 } 对于非虚的方法,无论被其所在类的实例调用,还是被这个类的派生类的实例调用,方法的执行方式不变。而对于虚方法,它的执行 方式可以被派生类改变,这种改变是通过方法的重载来实现的。 虚方法的重载形式 override 修饰符 返回的数据类型 方法名(参数表) { 方法体 } override 重写继承自基类的 virtural 方法,可以理解为拆掉老房子,在原址上建新房子,老房子再也找不到了(基类方法永远调用不到了)。 using System; class A { public void F(){Console.WriteLine(A.F);} public virtual void G(){Console.WriteLine(A.G);} } class B:A { new public void F(){Console.WriteLine(B.F);} public override void G(){Console.WriteLine(B.G);} } class Tese { static void Main(){ B b=new B(); A a=b; a.F(); b.F(); a.G(); b.G(); } } New和override的异同 * new和override的相同点: * 都可以对基类成员进行隐藏,都可以用base关键字调用基类的成员 * new和override的不同点: * 用override的基类的方法必须要用virtual,而new不必要 * 本质区别在于当派生类对象作为基类类型使用时,override 的执行派生类方法,new 的执行基类方法。如果作为派生类类型调用,则都是执行 override 或 new 之后的。 ? override 重写继承自基类的 virtural 方法,可以理解为拆掉老房子,在原址上建新房子,老房子再也找不到了(基类方法永远调用不到了)。 ?? new 隐藏继承自基类的 virtual 方法,老房子还留着,在旁边盖个新房,想住新房住新房(作为派生类对象调用),想住老房住老房(作为基类对象调用)。 ?? 当派生类中出现与基类同名的方法,而此方法前面未加 override 或 new 修饰符时,编译器会报警告,但不报错,真正执行时等同于加了 new。 例子 class A ??? { ??????? public virtual void print() ??????? { ??????????? Console.WriteLine(类A的函数); ??????? } ??? } ??? class ANew:A ??? { ??????? public new void print() ??????? { ??????????? Console.WriteLine(类ANew的函数); ??????? } ??? } ??? class AOverride : A ??? { ??????? public override void print() ??????? { ??????????? Console.WriteLine(类AOverride的函数); ??????? } ??? } 类ANew用关键字new重新定义了一个和基类同名函数,类AOverride 用override覆盖了基类的同名函数,那么区别就出来了: 1.使用ANew,AOverride 的对象调用函数print,当然出现的是他们类体内的函数 ??????????? ANew anew = new ANew(); ??????????? AOverride aover = new AOverride(); ??????????? anew.print();//---------》Console.WriteLine(类ANew的函数); ??????????? aover.print();//--------》 Console.WriteLine(类AOverride的函数); 2. 当使用基类的对象引用来调用print函数时,就出现了差别 ??????????? A[] Aarr = new A[2];

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档