我理解c#中的interface abstract virtual override和new(转)
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();//正确
void getAge(string s);//正确
}
实现interface的类
1.与继承类的格式一致,如 public class Chinese:IPerson{}
2.必须实现interface中的各个方法
例2,继承例1
public class Chinese:IPerson
{
public Chinese(){}//添加构造函数
public void getName(){}//实现getName()
public void getAge(){}//实现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 关键字
interface中的方法和abstract方法都要求实现
overrid和new
//override不能重写非虚方法或静态方法。
//所重写的基方法必须是虚拟的、抽象的或重写的。
//所以说虚(virtual)成员与重写(override)成员是配对使用的,
//虽然也可以用new来"隐藏"虚成员
//下面通过例子来看看重写与隐藏的区别,从而进一步理解虚成员的作用。
//重写部分----------
public class MyBaseClass
{
public virtual void DoSomething()
{
Console.WriteLine("Base imp");
}
}
public class MyDerivedClass:MyBaseClass
{
public override void DoSomething()
(
Console.WriteLine("Derived imp");
}
}
//其中重写方法将替换基类中的执行代码,这样下面的代码就将使用替换代码,
//即使这是通过基类进行的,情况也是这样:
MyDerivedClass myObj=new MyDerivedClass();
MyBaseClass myBaseObj;
myBaseObj=myObj;
myBaseObj.DoSomething();
//结果如下:
Derived imp
//另外,还可以使用下面的代码隐藏基类方法:
public class MyBaseClass
{
public virtual void DoSomething()
{
Console.WriteLine("Base imp");
}
}
public class MyDerivedClass:MyBaseClass
{
new public void DoSomething()
{
Console.WriteLine("Derived imp");
}
}
//基类方法不必是虚拟的,但结果是一样的,上面的代码只需要修改行。
//对于基类的虚拟方法和非虚拟方法来说,其结果如下:
Base imp
//尽管隐藏了基类的执行代码,但仍可以通过基类访问它。