abstract 修饰符可以和类、方法、属性、索引器及事件一起使用。在类声明中使用 abstract 修饰符以指示某个类只能是其他类的基类。标记为抽象或包含在抽象类中的成员必须通过从抽象类派生的类来实现。

抽象类具有以下特性:

  • 抽象类不能实例化。

  • 抽象类可以包含抽象方法和抽象访问器。

  • 不能用 sealed(C# 参考)修饰符修改抽象类,这意味着抽象类不能被继承。

  • 从抽象类派生的非抽象类必须包括继承的所有抽象方法和抽象访问器的实实现。

在方法或属性声明中使用 abstract 修饰符以指示方法或属性不包含实现。

抽象方法具有以下特性:

  • 抽象方法是隐式的虚方法。

  • 只允许在抽象类中使用抽象方法声明。

  • 因为抽象方法声明不提供实际的实现,所以没有方法体;方法声明只是以一个分号结束,并且在签名后没有大括号 ({ })。例如:

    1. public abstract void MyMethod();
  • 实现由一个重写方法override(C# 参考)提供,此重写方法是非抽象类的一个成员。

  • 在抽象方法声明中使用 staticvirtual 修饰符是错误的。

除了在声明和调用语法上不同外,抽象属性的行为与抽象方法一样。

  • 在静态属性上使用 abstract 修饰符是错误的。

  • 在派生类中,通过包括使用 override 修饰符的属性声明,可以重写抽象的继承属性。

抽象类必须为所有接口成员提供实现。

实现接口的抽象类可以将接口方法映射到抽象方法上。例如:

  1. interface I
  2. {
  3. void M();
  4. }
  5. abstract class C: I
  6. {
  7. public abstract void M();
  8. }

在具体用法如下实例:

新加一个基类:MothedBase.cs

  1. public abstract class MothedBase
  2. {
  3. #region Fields
  4. public List<string> ErrorList = new List<string>();
  5. public List<string> MessageList = new List<string>();
  6. #endregion
  7.  
  8. #region Properties
  9.  
  10. /// <summary>
  11. ///
  12. /// </summary>
  13. private string ConnectString
  14. {
  15. get
  16. {
  17. return ConfigurationManager.ConnectionStrings["ConnectString"].ConnectionString;
  18. }
  19. }
  20.  
  21.  
  22. #endregion
  23.  
  24. #region Entrance Method
  25.  
  26. /// <summary>
  27. ///
  28. /// </summary>
  29. public void ExcuteMigration()
  30. {
  31.  
  32.  
  33. SubmitMigration(this.SqlQueryGetAllAttachment, this.SqlQueryGetAllItems, this.SqlQueryGetFolder, this.SiteUrl);
  34.  
  35. }
  36.  
  37.  
  38. protected abstract string SiteUrl
  39. {
  40. get;
  41. }
  42. /// <summary>
  43. ///
  44. /// </summary>
  45. protected abstract bool IsMigrateToProductHomePage { get; }
  46. /// <summary>
  47. ///
  48. /// </summary>
  49. protected abstract List<string> NeedReplaceColumn { get; }
  50. /// <summary>
  51. ///
  52. /// </summary>
  53. protected abstract string SqlQueryGetAllItems { get; }
  54.  
  55. /// <summary>
  56. ///
  57. /// </summary>
  58. protected abstract string SqlQueryGetAllAttachment { get; }
  59.  
  60. protected virtual string SqlQueryGetFolder { get { return null; } }
  61. /// <summary>
  62. ///
  63. /// </summary>
  64. /// <param name="dtOriginalData"></param>
  65. protected abstract void ValidateOriginalData(DataTable dtOriginalData);
  66.  
  67. /// <summary>
  68. ///
  69. /// </summary>
  70. /// <param name="dtOriginalData"></param>
  71. protected abstract DataTable TransferData(DataTable dtOriginalData);
  72.  
  73. #endregion
  74.  
  75. #region Protected Methods
  76.  
  77.  
  78.  
  79.  
  80. /// <summary>
  81. ///
  82. /// </summary>
  83. /// <param name="sqlQuery"></param>
  84. /// <returns></returns>
  85. protected DataTable ExcuteOracleReader(string sqlQuery)
  86. {
  87. DataTable dtResult = new DataTable();
  88. if (!string.IsNullOrEmpty(sqlQuery))
  89. {
  90. OracleCommand command = null;
  91. IDataReader dataReader = null;
  92. OracleConnection conn = null;
  93.  
  94. try
  95. {
  96. conn = new OracleConnection(this.ConnectString);
  97. conn.Open();
  98. command = new OracleCommand(sqlQuery);
  99. command.Connection = conn;
  100. command.CommandType = CommandType.Text;
  101. dataReader = command.ExecuteReader();
  102. dtResult.Load(dataReader);
  103. }
  104. catch (Exception ex)
  105. {
  106. this.ErrorList.Add(ex.Message);
  107. }
  108. finally
  109. {
  110. if (conn.State != ConnectionState.Closed)
  111. {
  112. conn.Close();
  113. conn.Dispose();
  114. }
  115.  
  116. if ((dataReader != null) && (dataReader.IsClosed == false))
  117. {
  118. dataReader.Close();
  119. dataReader.Dispose();
  120. }
  121.  
  122. if (command != null)
  123. {
  124. command.Dispose();
  125. }
  126. }
  127. }
  128.  
  129. return dtResult;
  130. }
  131.  
  132. #endregion
  133.  
  134. #region Private Methods
  135.  
  136.  
  137. /// <summary>
  138. ///
  139. /// </summary>
  140. /// <param name="GetAllAttachment"></param>
  141. /// <param name="GetAllItems"></param>
  142. /// <param name="TheSiteUrl"></param>
  143. private void SubmitMigration(string GetAllAttachment, string GetAllItems, string GetFolderItem, string TheSiteUrl)
  144. {
  145. DataTable dtAttachment = null;
  146. DataTable dtOriginalData = null;
  147. //Get data and attachment form oracle database.
  148. if (!string.IsNullOrEmpty(this.SqlQueryGetAllAttachment))
  149. dtAttachment = this.ExcuteOracleReader(GetAllAttachment);
  150. if (!string.IsNullOrEmpty(this.SqlQueryGetAllItems))
  151. dtOriginalData = this.ExcuteOracleReader(GetAllItems);
  152. }
  153.  
  154.  
  155.  
  156.  
  157. #endregion
  158.  
  159. }

然后再加一个UseMothedBase类引用MothedBase基类,代码如下:

  1. public class UseMothedBase:MothedBase
  2. {
  3. protected override string SiteUrl
  4. {
  5. get { return ""; }
  6. }
  7.  
  8. protected override bool IsMigrateToProductHomePage
  9. {
  10. get { return ""; }
  11. }
  12.  
  13. protected override List<string> NeedReplaceColumn
  14. {
  15. get { throw new NotImplementedException(); }
  16. }
  17.  
  18. protected override string SqlQueryGetAllItems
  19. {
  20. get { return ""; }
  21. }
  22.  
  23. protected override string SqlQueryGetAllAttachment
  24. {
  25. get { return ""; }
  26. }
  27.  
  28. protected override void ValidateOriginalData(System.Data.DataTable dtOriginalData)
  29. {
  30. }
  31.  
  32. protected override System.Data.DataTable TransferData(System.Data.DataTable dtOriginalData)
  33. {
  34. return new DataTable();
  35. }
  36. }

然后再在main.cs 引用它们,代码如下:

  1. static void Main()
  2. {
  3. MothedBase usemoth = new UseMothedBase();
  4. usemoth.ExcuteMigration();
  5. }

就样就是一个Abstract Factory 简单用法了,可以概据各自的需求丰富下,让它使用灵活.

版权声明:本文为springyangwc原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/springyangwc/archive/2011/12/21/1987096.html