日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

C#面向對象設計原則之開閉原則_C#教程

作者:.NET開發菜鳥 ? 更新時間: 2022-05-03 編程語言

開閉原則(OCP)

定義:對擴展開發,對修改關閉。
好處:

  • 適應性和靈活性。
  • 穩定性和延續性。
  • 可復用性與可維護性。

解釋說明:開閉原則指的是兩方面:對功能擴展開發,對修改進行關閉;有時當用戶要求或需求發生變化時,我們不得不打開原來的代碼進行修改,進行功能的擴展或增加,這種設計如果應用到我們以后的項目開發中會導致嚴重的問題,這樣容易導致意外的錯誤。好的程序,應該保證在我們進行程序擴展時,不會更改以前的代碼。如何才能保證這樣的效果呢?我們在定義一個類的功能時:最好先定義他的抽象類或接口,這樣在功能擴展時,我們只需要在原來抽象類和接口的基礎上編寫新的實現類和子類,這樣既能擴展功能又不影響以前的功能。

示例:

定義數據庫鏈接的接口

using System;
using System.Collections.Generic;
using System.Data.Common;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace 開閉原則_OCP_
{
    /// 
    /// 數據庫連接
    /// 
    public interface IDbConnection
    {
        public DbConnection GetConnection();   
    }
}

分別定義兩個接口的實現類

SQL Server數據庫實現類:

using System;
using System.Collections.Generic;
using System.Data.Common;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient;

namespace 開閉原則_OCP_
{
    public class SqlServerDbConnection :IDbConnection
    {
        public DbConnection GetConnection()
        {
            // 連接數據庫并返回
            return new SqlConnection();
        }
    }
}

Oracle數據庫實現類

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.OracleClient;
using System.Data.Common;
using System.Data.OracleClient;

namespace 開閉原則_OCP_
{
   public  class OracleDbConnection:IDbConnection
    {
        public DbConnection GetConnection()
        {
            // 連接數據庫并返回
            return new OracleConnection();
        }
    }
}

如果又增加了一個數據庫,只需要在定義一個接口的實現類就可以。接口不會發生變化,接口的實現類實現了多樣性,這樣就實現了開閉原則。

代碼下載鏈接:點此下載

原文鏈接:https://www.cnblogs.com/dotnet261010/p/7349890.html

欄目分類
最近更新