C#的static,interface,virtual,abstract,override的区别用法

简介:

C# 是面向对象的程序设计语言,每一个函数都属于一个类。 
Static:当一个方法被声明为Static时,这个方法是一个静态方法,编译器会在编译时保留这个方法的实现。也就是说,这个方法属于类,但是不属于任何成员,不管这个类的实例是否存在,它们都会存在。就像入口函数Static void Main,因为它是静态函数,所以可以直接被调用。 

Virtua:当一个方法被声明为Virtual时,它是一个虚拟方法,直到你使用ClassName variable = new ClassName();声明一个类的实例之前,它都不存在于真实的内存空间中。这个关键字在类的继承中非常常用,用来提供类方法的多态性支持。

overrride:表示重写 这个类是继承于Shape类 
public override double Area 这个属性再shape中肯定存在 但是这里我们不想用shape中的 所以要重写 
virtual,abstract是告诉其它想继承于他的类 你可以重写我的这个方法或属性,否则不允许。

一个生动的例子 :老爸表示基类(被继承的类) 儿子表示子类(继承的类)

老爸用virtual告诉儿子:"孩子,你要继承我的事业,在这块上面可以自己继续发展你自己的"

儿子用override告诉全世界:"这个我可不是直接拿我爸的,他只是指个路给我,是我自己奋斗出来的" 

abstract:抽象方法声明使用,是必须被派生类覆写的方法,抽象类就是用来被继承的;可以看成是没有实现体的虚方法;如果类中包含抽象方法,那么类就必须定义为抽象类,不论是否还包含其他一般方法;抽象类不能有实体的。
详解----------------------------------------------

interface用来声明接口

1.只提供一些方法规约,不提供方法主体. 如:

public interface IPerson

{

    void getName();//不包含方法主体

}

2.方法不能用public abstract等修饰,无字段变量,无构造函数。

3.方法可包含参数。 如

public interface IPerson

{

    void getAge(string s);

}

一个例子(例1):

public interface IPerson

{

   IPerson();              //错误

   string name;            //错误

   public void getIDcard();//错误

   void getName();         //right

   void getAge(string s); //right

}

实现interface的类

1.与继承类的格式一致,如 public class Chinese:IPerson{}

2.必须实现 interface 中的各个方法

   例2,继承例1

public class Chinese:IPerson

{

   public Chinese(){}                  //添加构造

   public void getName(){}          //实现getName()

   public void getAge(string s){} //实现getAge()

}

abstract声明抽象类、抽象方法

1.抽象方法所在类必须为抽象类

2.抽象类不能直接实例化,必须由其派生类实现。

3.抽象方法不包含方法主体,必须由派生类以override方式实现此方法,这点跟interface中的方法类似

public abstract class Book

{

public Book()

{  

}

public abstract void getPrice();      //抽象方法,不含主体

public virtual void getName()   //虚方法,可覆盖

{

      Console.WriteLine("this is a test:virtual getName()");

}

public virtual void getContent()   //虚方法,可覆盖

{

      Console.WriteLine("this is a test:virtual getContent()");

}

public void getDate()                           //一般方法,若在派生类中重写,须使用new关键字

{

      Console.WriteLine("this is a test: void getDate()");

   }

}

public class JavaBook:Book

{

      public override void getPrice()   //实现抽象方法,必须实现

      {

           Console.WriteLine("this is a test:JavaBook override abstract getPrice()");

      }

      public override void getName()   //覆盖原方法,不是必须的

      {

           Console.WriteLine("this is a test:JavaBook override virtual getName()");

      }

}

测试如下:

public class test

{

   public test()

   {

    JavaBook jbook=new JavaBook();

         jbook.getPrice();      //将调用JavaBook中getPrice()

         jbook.getName();       //将调用JavaBook中getName()

         jbook.getContent();    //将调用Book中getContent()

         jbook.getDate();       //将调用Book中getDate()

    }

   public static void Main()

   {

       test t=new test();

   }

}

virtual标记方法为虚方法

1.可在派生类中以override覆盖此方法

2.不覆盖也可由对象调用

3.无此标记的方法(也无其他标记),重写时需用new隐藏原方法

abstract 与virtual : 方法重写时都使用 override 关键字


接口定义以大写字母I开头。方法只定义其名称,在C#中,方法默认是公有方法;用public修饰方法是不允许的,否则会出现编译错误;接口可以从别的接口继承,如果是继承多个接口,则父接口列表用逗号间隔。 
接口可以通过类来实现,当类的基列表同时包含基类和接口时,列表中首先出现的是基类;类必须要实现其抽象方法; 
接口使用:见代码(转)

interface使用 
interface使用(实例一)

using System; 
namespace Dage.Interface 

//打印机接口 
public interface IPrint 

string returnPrintName(); 


//-------------------------------------------- 
using System; 
using Dage.Interface; 
namespace Dage.Print 

//HP牌打印机类 
public class HP: IPrint 

public string returnPrintName() 

return "这是HP牌打印机"; 



//-------------------------------------------- 
using System; 
namespace Dage.Print 

//Eps牌打印机类 
public class Eps: IPrint 

public string returnPrintName() 

return "这是Eps牌打印机"; 



//-------------------------------------------- 
using System; 
using Dage.Interface; 
namespace Dage 

//打印类 
public class Printer 

public Printer() 
{} 
public string PrintName(IPrint iPrint) 

return iPrint.returnPrintName(); 



//-------------------------------------------- 
--WinFrom中调用代码: 
private void button1_Click(object sender, System.EventArgs e) 

Printer p= new Printer(); 
switch (this.comboBox1.Text) 

case "HP": 
MessageBox.Show(p.PrintName(new HP())); 
break; 
case "Eps": 
MessageBox.Show(p.PrintName(new Eps())); 
break; 
default: 
MessageBox.Show("没有发现这个品牌!"); 
break; 

}

分类:  项目有关


本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2011/11/18/2254019.html,如需转载请自行联系原作者
目录
相关文章
|
6月前
|
安全 C#
C# List基本用法
C# List基本用法
|
11天前
|
Java 物联网 编译器
C#一分钟浅谈:.NET Core 与 .NET 5 区别
本文对比了 .NET Core 和 .NET 5,从历史背景、主要区别、常见问题及易错点等方面进行了详细分析。.NET Core 侧重跨平台支持和高性能,而 .NET 5 在此基础上统一了 .NET 生态系统,增加了更多新特性和优化。开发者可根据具体需求选择合适的版本。
35 7
|
15天前
|
开发框架 安全 .NET
C#面:Server.UrlEncode、HttpUtility.UrlDecode的区别
通过上述详细的解释和实例分析,相信大家对 `Server.UrlEncode` 和 `HttpUtility.UrlDecode` 的区别有了更深刻的理解,并能在实际开发中灵活运用。
25 0
|
1月前
|
网络协议 网络性能优化 C#
C# 一分钟浅谈:UDP 与 TCP 协议区别
【10月更文挑战第8天】在网络编程中,传输层协议的选择对应用程序的性能和可靠性至关重要。本文介绍了 TCP 和 UDP 两种常用协议的基础概念、区别及应用场景,并通过 C# 代码示例详细说明了如何处理常见的问题和易错点。TCP 适用于需要可靠传输和顺序保证的场景,而 UDP 适用于对延迟敏感且可以容忍一定数据丢失的实时应用。
35 1
|
5月前
|
存储 安全 Java
程序与技术分享:C#值类型和引用类型的区别
程序与技术分享:C#值类型和引用类型的区别
44 0
|
1月前
|
C# 开发者
【捞底干货】C#中equals和==运算符的区别
【捞底干货】C#中equals和==运算符的区别
28 1
|
1月前
|
C#
C# 接口(Interface)
接口定义了所有类继承接口时应遵循的语法合同。接口定义了语法合同 "是什么" 部分,派生类定义了语法合同 "怎么做" 部分。 接口定义了属性、方法和事件,这些都是接口的成员。接口只包含了成员的声明。成员的定义是派生类的责任。接口提供了派生类应遵循的标准结构。 接口使得实现接口的类或结构在形式上保持一致。 抽象类在某种程度上与接口类似,但是,它们大多只是用在当只有少数方法由基类声明由派生类实现时。 接口本身并不实现任何功能,它只是和声明实现该接口的对象订立一个必须实现哪些行为的契约。 抽象类不能直接实例化,但允许派生出具体的,具有实际功能的类。
48 9
|
2月前
|
C# 索引
C# 一分钟浅谈:接口与抽象类的区别及使用
【9月更文挑战第2天】本文详细对比了面向对象编程中接口与抽象类的概念及区别。接口定义了行为规范,强制实现类提供具体实现;抽象类则既能定义抽象方法也能提供具体实现。文章通过具体示例介绍了如何使用接口和抽象类,并探讨了其实现方式、继承限制及实例化差异。最后总结了选择接口或抽象类应基于具体设计需求。掌握这两者有助于编写高质量的面向对象程序。
118 5
|
3月前
|
C#
C#中的overload,overwrite,override的语义区别
以上概念是面向对象编程中实现多态性和继承的重要基石。理解它们之间的区别对于编写清晰、可维护的代码至关重要。
128 7
|
3月前
|
C# 索引
C#中的virtual和override关键字
C#中的virtual和override关键字
45 3