您的位置:首页 > 编程语言 > C#

我理解c#中的interface abstract virtual override和new(转)

2008-10-23 10:44 447 查看
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

//尽管隐藏了基类的执行代码,但仍可以通过基类访问它。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: