面向對象設計原則二:開閉原則(OCP)
阿新 • • 發佈:2017-08-12
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 :IDbConnection12 { 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)