interface用来声明接口

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方法都要求实现


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;)}
}

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值