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 关键字
interface中的方法和abstract方法都要求实现
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 关键字
interface中的方法和abstract方法都要求实现
C#中的接口
1 .都是“虚的”不能被实例化,这也是接口中为什么不能包含字段--成员变量的原因2.正因为接口是虚的,所以接口内的索引,属性,时间等只能有声明,而不能在接口内实现,具体如何实现是派生接口或者派生类的事.
3 .都具有模板的性质,如果一个接口或者类从某一个接口继承,它将自动具有被集成者的特征(包括索引,属性,函数,实践等).
4 .接口支持多重继承,而C#中,类之支持单一继承,接口实际表示的是一种承载能力,
下面是接口的一个简单定义:
interface
SampInterface1
{
string
this [ int index]
{
get ;
set
}
;
event EventHandler Event;
void Find( int value );
// 注意此处没有
{
}
string Po
int
{
get ;
set
}
;
}
上面的接口定义了一个索引
this ,一个实践Event,一个方法Find和一个属性Point.
public interface SampIneterface:SampIneterface1{
pravite int a = 1 ;
void find ( int value)
{
a += value;
}
event EventHandler Event;
protected void onEvent()
{
if (Event = null )
{ return Event( this .System.EventAgrs.Empty;)}
}
}
1 .都是“虚的”不能被实例化,这也是接口中为什么不能包含字段--成员变量的原因2.正因为接口是虚的,所以接口内的索引,属性,时间等只能有声明,而不能在接口内实现,具体如何实现是派生接口或者派生类的事.
3 .都具有模板的性质,如果一个接口或者类从某一个接口继承,它将自动具有被集成者的特征(包括索引,属性,函数,实践等).
4 .接口支持多重继承,而C#中,类之支持单一继承,接口实际表示的是一种承载能力,
下面是接口的一个简单定义:
interface
SampInterface1
{
string
this [ int index]
{
get ;
set
}
;
event EventHandler Event;
void Find( int value );
// 注意此处没有
{
}
string Po
int
{
get ;
set
}
;
}
上面的接口定义了一个索引
this ,一个实践Event,一个方法Find和一个属性Point.
public interface SampIneterface:SampIneterface1{
pravite int a = 1 ;
void find ( int value)
{
a += value;
}
event EventHandler Event;
protected void onEvent()
{
if (Event = null )
{ return Event( this .System.EventAgrs.Empty;)}
}
}