C#中abstract的用法詳解


abstract可以用來修飾類,方法,屬性,索引器和時間,這里不包括字段. 使用abstrac修飾的類,該類只能作為其他類的基類,不能實例化,而且abstract修飾的成員在派生類中必須全部實現,不允許部分實現,否則編譯異常. 如:

using System;
namespace ConsoleApplication8 
{ 
  class Program 
  { 
    static void Main(string[] args) 
    { 
      BClass b = new BClass(); 
      b.m1(); 
    } 
  } 
  abstract class AClass 
  { 
      public abstract void m1(); 
      public abstract void m2(); 
  } 
  class BClass : AClass 
  { 
    public override void m1() 
    { 
      throw new NotImplementedException(); 
    } 
    //public override void m2() 
    //{ 
      // throw new NotImplementedException(); 
    //} 
  } 
}

 

 Abstract classes have the following features:

抽象類擁有如下特征:

1,抽象類不能被實例化, 但可以有實例構造函數, 類是否可以實例化取決於是否擁有實例化的權限 (對於抽象類的權限是abstract, 禁止實例化),
即使不提供構造函數, 編譯器也會提供默認構造函數;

2,抽象類可以包含抽象方法和訪問器;

3,抽象類不能使用sealed修飾, sealed意為不能被繼承;

4,所有繼承自抽象類的非抽象類必須實現所有的抽象成員,包括方法,屬性,索引器,事件;

abstract修飾的方法有如下特征:

1,抽象方法即是虛擬方法(隱含);

2,抽象方法只能在抽象類中聲明;

3,因為抽象方法只是聲明, 不提供實現, 所以方法只以分號結束,沒有方法體,即沒有花括號部分;如

public abstract void MyMethod();

4,override修飾的覆蓋方法提供實現,且只能作為非抽象類的成員;

5,在抽象方法的聲明上不能使用virtual或者是static修飾.即不能是靜態的,又因為abstract已經是虛擬的,無需再用virtual強調.
抽象屬性盡管在行為上與抽象方法相似,但仍有有如下不同:

1,不能在靜態屬性上應用abstract修飾符;

2,抽象屬性在非抽象的派生類中覆蓋重寫,使用override修飾符;

抽象類與接口:

1,抽象類必須提供所有接口成員的實現;

2,繼承接口的抽象類可以將接口的成員映射位抽象方法.

 

interface I 
{ 
void M(); 
} 
abstract class C: I 
{ 
public abstract void M(); 
} 
抽象類實例: 
// abstract_keyword.cs 
// 抽象類 
using System; 
abstract class BaseClass // 抽象類 
{ 
protected int _x = 100; //抽象類可以定義字段,但不可以是抽象字段,也沒有這一說法. 
protected int _y = 150; 
public BaseClass(int i) //可以定義實例構造函數,僅供派生的非抽象類調用; 這里顯式提供構造函數,編譯器將不再提供默認構造函數. 
{ 
fielda = i; 
} 
public BaseClass() 
{ 
} 
private int fielda; 
public static int fieldsa = 0; 
public abstract void AbstractMethod(); // 抽象方法 
public abstract int X { get; } //抽象屬性 
public abstract int Y { get; } 
public abstract string IdxString { get; set; } //抽象屬性 
public abstract char this[int i] { get; } //抽象索引器 
}
class DerivedClass : BaseClass 
{ 
private string idxstring; 
private int fieldb; 
//如果基類中沒有定義無參構造函數,但存在有參數的構造函數, 
//那么這里派生類得構造函數必須調用基類的有參數構造函數,否則編譯出錯 
public DerivedClass(int p) 
: base(p) //這里的:base(p)可省略,因為基類定義了默認的無參構造函數 
{ 
fieldb = p; 
} 
public override string IdxString //覆蓋重新屬性 
{ 
get
{ 
return idxstring; 
} 
set
{ 
idxstring = value; 
} 
} 
public override char this[int i] //覆蓋重寫索引器 
{ 
get { return IdxString[i]; } 
} 
public override void AbstractMethod() 
{ 
_x++; 
_y++; 
}
public override int X // 覆蓋重寫屬性
{
 get
 {
  return _x + 10;
 }
}
 
public override int Y // 覆蓋重寫屬性
{
 get
 {
  return _y + 10;
 }
}
 
static void Main()
{
 DerivedClass o = new DerivedClass(1);
 o.AbstractMethod();
 Console.WriteLine("x = {0}, y = {1}", o.X, o.Y);
}
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM