c#中abstract、override、new、virtual、sealed使用和示例
原文地址:http://blog.csdn.net/richerg85/article/details/7407544
abstract
修饰类名为抽象类,修饰方法为抽象方法。如果一个类为抽象类,则这个类智能是其他某个类的基类。抽象方法在抽象类中没有函数体。抽象类中的抽象方法是没有方法体的,继承其的子类必须实现抽象类的抽象方法。
抽象类有如下特征:
- 抽象类不能实例化
- 抽象类的派生类必须实现所有抽象方法
- 抽象类中的抽象方法是没有方法体的,继承其的子类必须实现抽象类的抽象方法
- 抽象方法是隐式的虚方法
- 只允许在抽象类中使用抽象方法声明
- 抽象方法在抽象类中没有方法体
- 在抽象方法声明中,不能使用static或者virtual修饰符
- abstract class A //abstract 关键字在class前面
- {
- public abstract void run();//方法是将关键字abstract 添加到方法的返回类型的前面
- }
abstract class A //abstract 关键字在class前面
{
public abstract void run();//方法是将关键字abstract 添加到方法的返回类型的前面
}
- abstract class A
- {
- public virtual void MethodA()
- {
- //do something
- }
- public abstract void run();
- }
- public class B:A
- {
- public override void MethodA()
- {
- //do somthing
- }
- public virtual void run()
- {
- //do something
- }
- }
abstract class A
{
public virtual void MethodA()
{
//do something
}
public abstract void run();
}
public class B:A
{
public override void MethodA()
{
//do somthing
}
public virtual void run()
{
//do something
}
}
- 作为运算符用来创建类的一个对象。 Class obj = new Class();
- 作为修饰符。
- 用于在泛型声明中约束可能用作类型参数的参数类型。(这个不太清楚)
- // Define the base class
- class Car
- {
- public virtual void DescribeCar()
- {
- System.Console.WriteLine("Four wheels and an engine.");
- }
- }
- // Define the derived classes
- class ConvertibleCar : Car
- {
- public new void DescribeCar()
- {
- System.Console.WriteLine("A roof that opens up.");
- }
- }
- class Minivan : Car
- {
- public override void DescribeCar()
- {
- System.Console.WriteLine("Carries seven people.");
- }
- }
- public class Program
- {
- public static void Main()
- {
- Car car1 = new Car();
- car1.DescribeCar();
- System.Console.WriteLine("----------");
- Car car2 = new ConvertibleCar();
- car2.DescribeCar();
- System.Console.WriteLine("----------");
- Car car3 = new Minivan();
- car3.DescribeCar();
- System.Console.WriteLine("----------");
- System.Console.ReadKey();
- }
- }
// Define the base class
class Car
{
public virtual void DescribeCar()
{
System.Console.WriteLine("Four wheels and an engine.");
}
}
// Define the derived classes
class ConvertibleCar : Car
{
public new void DescribeCar()
{
System.Console.WriteLine("A roof that opens up.");
}
} class Minivan : Car
{
public override void DescribeCar()
{
System.Console.WriteLine("Carries seven people.");
}
}
public class Program
{
public static void Main()
{
Car car1 = new Car();
car1.DescribeCar();
System.Console.WriteLine("----------"); Car car2 = new ConvertibleCar();
car2.DescribeCar();
System.Console.WriteLine("----------"); Car car3 = new Minivan();
car3.DescribeCar();
System.Console.WriteLine("----------");
System.Console.ReadKey();
}
}
- class X
- {
- protected virtual void F() { Console.WriteLine("X.F"); }
- protected virtual void F2() { Console.WriteLine("X.F2"); }
- }
- class Y : X
- {
- sealed protected override void F() { Console.WriteLine("Y.F"); }
- protected override void F2() { Console.WriteLine("X.F3"); }
- }
- class Z : Y
- {
- // Attempting to override F causes compiler error CS0239.
- // protected override void F() { Console.WriteLine("C.F"); }//sealed修饰的方法是不允许继承的
- // Overriding F2 is allowed.
- protected override void F2() { Console.WriteLine("Z.F2"); }
- }
class X {
protected virtual void F() { Console.WriteLine("X.F"); }
protected virtual void F2() { Console.WriteLine("X.F2"); }
}
class Y : X
{
sealed protected override void F() { Console.WriteLine("Y.F"); }
protected override void F2() { Console.WriteLine("X.F3"); }
}
class Z : Y
{
// Attempting to override F causes compiler error CS0239.
// protected override void F() { Console.WriteLine("C.F"); }//sealed修饰的方法是不允许继承的 // Overriding F2 is allowed.
protected override void F2() { Console.WriteLine("Z.F2"); }
}
- namespace testVirtualF
- {
- interface BaseInterface
- {
- void doWork();
- }
- public abstract class Base:BaseInterface
- {
- public virtual void work()
- {
- Console.WriteLine("基类---现在是上班时间");
- }
- public virtual void outWork()
- {
- Console.WriteLine("基类---现在是下班时间");
- }
- public abstract void play();//声明抽象方法,只能在抽象方法中
- public abstract void doWork();//实现接口的抽象类,可以将接口方法映射到抽象方法中
- }
- public class Employer:Base
- {
- public new void work()
- {
- Console.WriteLine("子类(new)---现在是上班时间");
- }
- public override void outWork()
- {
- Console.WriteLine("子类(override)---现在是下班时间");
- }
- public override void play()
- {
- Console.WriteLine("子类(override)---父类抽象方法");
- }
- public override void doWork()
- {
- Console.WriteLine("父类抽象方法--doWork");
- }
- }
- class Program
- {
- static void Main(string[] args)
- {
- /*Employer emp = new Employer();
- emp.work();
- emp.outWork();
- emp.play();*/
- /*输出结果
- * 子类(new)---现在是上班时间
- * 子类(override)---现在是下班时间
- */
- /*Employer emp = new Employer();
- Base b = (Base)emp;
- //b.ID = "123";
- b.work();
- b.outWork();
- b.play();*/
- /*执行结果
- * 基类---现在是上班时间
- * 子类(new)---现在是上班时间
- * 子类(override)---现在是下班时间
- */
- Base b = new Employer();
- b.work();
- b.outWork();
- b.play();
- /*执行结果
- * 基类---现在是上班时间
- * 子类(new)---现在是上班时间
- * 子类(override)---现在是下班时间
- */
- }
- }
- }
c#中abstract、override、new、virtual、sealed使用和示例的更多相关文章
- C#--virtual,abstract,override,new,sealed
virtual:使用此关键字,可以使其在派生类中被重写. abstract:抽象方法,由子类重写,或继续为抽象方法存在,并由其子子类实现. override: 重写父类方法,属性,或事件的抽象实现或虚 ...
- Abstract和Virtual和interface , 派生类中重写 override / new关键字
http://www.cnblogs.com/blsong/archive/2010/08/12/1798064.html C#中Abstract和Virtual 在C#的学习中,容易混淆virtua ...
- C#中Abstract和Virtual的区别
c# 中 Abstract和Virtual比较容易混淆,都与继承有关,并且涉及override的使用.下面讨论一下二者的区别: 一.Virtual方法(虚方法) virtual 关键字用于在基类中修饰 ...
- C#中Abstract和Virtual
C#中Abstract和Virtual 在C#的学习中,容易混淆virtual方法和abstract方法的使用,现在来讨论一下二者的区别.二者都牵涉到在派生类中与override的配合使用. 一.Vi ...
- C#中abstract和virtual区别
在C#的学习中,容易混淆virtual方法和abstract方法的使用,现在来讨论一下二者的区别.二者都牵涉到在派生类中与override的配合使用. 一.Virtual方法(虚方法) virtual ...
- C#中的interface、virtual和abstract
一.Abstract: abstract方法必须在abstarct类中声明,没有默认实现,子类必须实现. 二.Virtual: virtual方法可以声明在abstract类中,也可以声明在非abst ...
- C#中Abstract和Virtual 【转】
http://www.cnblogs.com/blsong/archive/2010/08/12/1798064.html 在C#的学习中,容易混淆virtual方法和abstract方法的使用,现在 ...
- c#和java中的方法覆盖——virtual、override、new
多态和覆盖 多态是面向对象编程中最为重要的概念之一,而覆盖又是体现多态最重要的方面.对于像c#和java这样的面向对象编程的语言来说,实现了在编译时只检查接口是否具备,而不需关心最终的实现,即最终的实 ...
- C#中Abstract和Virtual[转载]
原文:http://www.cnblogs.com/blsong/archive/2010/08/12/1798064.html 在C#的学习中,容易混淆virtual方法和abstract方法的使用 ...
- 浅析C#中new、override、virtual关键字的区别
Virtual : virtual 关键字用于修饰方法.属性.索引器或事件声明,并使它们可以在派生类中被重写. 默认情况下,方法是非虚拟的.不能重写非虚方法. virtual 修饰符不能与 stati ...
随机推荐
- P2257 YY的GCD (莫比乌斯反演)
[题目链接] https://www.luogu.org/problemnew/show/P2257 // luogu-judger-enable-o2 /* -------------------- ...
- LeetCode74.搜索二维矩阵
74.搜索二维矩阵 描述 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 示 ...
- 在URL地址栏中显示ico
<!-- 在URL地址栏中显示ico --> <link Rel="SHORTCUT ICON" href="imag ...
- P4294 [WC2008]游览计划
传送门 斯坦纳树 给一个联通图,求 $k$ 个关键点联通的最小生成树权值 设 $f[o][i]$ 表示当前关键点选择状态为 $o$ ,以点 $i$ 为根的树的最小权值 初始 $f[1<<( ...
- Apache Shiro(四)-登录认证和权限管理WEB支持(Servlet)
新建web项目 web.xml 修改web.xml,在里面加了个过滤器. 这个过滤器的作用,简单的说,就是 Shiro 入门里的TestShiro 这部分的工作,悄悄的干了. //加载配置文件,并获取 ...
- linux的运行模式
一. 运行模式 运行模式也可以称为运行级别. 在Linux中存在一个进程:init(initialize,初始化),进程id是1 该进程存在一个对应的配置文件:inittab(系统运行级别配置文件,位 ...
- http请求报头和响应报头(1)
1.web端不可避免的http缓存机制,要理解缓存机制,先来了解下http的请求报文和响应报文的内容 2.请求报文 2.1请求行 请求行三部分组成:请求方法.URL以及版本协议 请求的方法有G ...
- linux中安装软件,查看、卸载已安装软件方法
各种主流Linux发行版都采用了某种形式的包管理系统(PMS)来控制软件和库的安装. 软件包存储在服务器上,可以利用本地Linux系统上的PMS工具通过互联网访问.这些服务器称为仓库. 由于Linux ...
- vue之理解异步更新 --- nextTick
默认情况下,vue中DOM的更新是异步执行的,理解这一点非常重要. 当侦测到数据变化时,Vue会打开一个队列,然后把在同一个事件循环(event loop)当中观察到的数据变化的watcher推送进入 ...
- 牛客网Java刷题知识点之拥塞发生的主要原因、TCP拥塞控制、TCP流量控制、TCP拥塞控制的四大过程(慢启动、拥塞避免、快速重传、快速恢复)
不多说,直接上干货! 福利 => 每天都推送 欢迎大家,关注微信扫码并加入我的4个微信公众号: 大数据躺过的坑 Java从入门到架构师 人工智能躺过的坑 ...