1. 程式人生 > >面向對象設計原則二:開閉原則(OCP)

面向對象設計原則二:開閉原則(OCP)

name 返回 展開 打開 設計原則 data turn acl int

開閉原則(OCP)
定義:對擴展開發,對修改關閉。
好處:
適應性和靈活性。
穩定性和延續性。
可復用性與可維護性。

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

示例:

定義數據庫鏈接的接口

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

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

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

SQL Server數據庫實現類:

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Data.Common;
 4 using System.Linq;
 5 using System.Text;
 6 using System.Threading.Tasks;
 7 using System.Data.SqlClient;
 8 
 9 namespace 開閉原則_OCP_
10 {
11     public class SqlServerDbConnection :IDbConnection
12 { 13 public DbConnection GetConnection() 14 { 15 // 連接數據庫並返回 16 return new SqlConnection(); 17 } 18 } 19 }

Oracle數據庫實現類

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Text;
 5 using System.Threading.Tasks;
 6 using System.Data.OracleClient;
 7 using System.Data.Common;
 8 using System.Data.OracleClient;
 9 
10 namespace 開閉原則_OCP_
11 {
12    public  class OracleDbConnection:IDbConnection
13     {
14         public DbConnection GetConnection()
15         {
16             // 連接數據庫並返回
17             return new OracleConnection();
18         }
19     }
20 }

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

面向對象設計原則二:開閉原則(OCP)