Java程式員應該瞭解的10個面向對象設計原則

来源:http://www.cnblogs.com/whyhappy/archive/2016/11/06/5538035.html
-Advertisement-
Play Games

面向對象設計原則: 是OOPS(Object-Oriented Programming System,面向對象的程式設計系統)編程的核心,但大多數Java程式員追逐像Singleton、Decorator、Observer這樣的設計模式,而不重視面向對象的分析和設計。甚至還有經驗豐富的Java程式員 ...


 

面向對象設計原則:

是OOPS(Object-Oriented Programming System,面向對象的程式設計系統)編程的核心,但大多數Java程式員追逐像SingletonDecoratorObserver這樣的設計模式,而不重視面向對象的分析和設計。甚至還有經驗豐富的Java程式員沒有聽說過OOPS和SOLID設計原則,他們根本不知道設計原則的好處,也不知道如何依照這些原則來進行編程。

眾所周知,Java編程最基本的原則就是要追求高內聚和低耦合的解決方案和代碼模塊設計。查看Apache和Sun的開放源代碼能幫助你發現其他Java設計原則在這些代碼中的實際運用。Java Development Kit則遵循以下模式:BorderFactory類中的工廠模式、Runtime類中的單件模式。你可以通過Joshua Bloch的《Effective Java》一書來瞭解更多信息。我個人偏向的另一種面向對象的設計模式是Kathy Sierra的Head First Design Pattern以及Head First Object Oriented Analysis and Design

雖然實際案例是學習設計原則或模式的最佳途徑,但通過本文的介紹,沒有接觸過這些原則或還在學習階段的Java程式員也能夠瞭解這10個面向對象的設計原則。其實每條原則都需要大量的篇幅才能講清楚,但我會儘力做到言簡意賅。

原則1:DRY(Don't repeat yourself)

即不要寫重覆的代碼,而是用“abstraction”類來抽象公有的東西。如果你需要多次用到一個硬編碼值,那麼可以設為公共常量;如果你要在兩個以上的地方使用一個代碼塊,那麼可以將它設為一個獨立的方法。SOLID設計原則的優點是易於維護,但要註意,不要濫用,duplicate 不是針對代碼,而是針對功能。這意味著,即使用公共代碼來驗證OrderID和SSN,二者也不會是相同的。使用公共代碼來實現兩個不同的功能,其實就是近似地把這兩個功能永遠捆綁到了一起,如果OrderID改變了其格式,SSN驗證代碼也會中斷。因此要慎用這種組合,不要隨意捆綁類似但不相關的功能。

原則2:封裝變化

在軟體領域中唯一不變的就是“Change”,因此封裝你認為或猜測未來將發生變化的代碼。OOPS設計模式的優點在於易於測試和維護封裝的代碼。如果你使用Java編碼,可以預設私有化變數和方法,並逐步增加訪問許可權,比如從private到protected和not public。有幾種Java設計模式也使用封裝,比如Factory設計模式是封裝“對象創建”,其靈活性使得之後引進新代碼不會對現有的代碼造成影響。

原則3:開閉原則

即對擴展開放,對修改關閉。這是另一種非常棒的設計原則,可以防止其他人更改已經測試好的代碼。理論上,可以在不修改原有的模塊的基礎上,擴展功能。這也是開閉原則的宗旨。

原則4:單一職責原則

類被修改的幾率很大,因此應該專註於單一的功能。如果你把多個功能放在同一個類中,功能之間就形成了關聯,改變其中一個功能,有可能中止另一個功能,這時就需要新一輪的測試來避免可能出現的問題。

原則5:依賴註入或倒置原則

這個設計原則的亮點在於任何被DI框架註入的類很容易用mock對象進行測試和維護,因為對象創建代碼集中在框架中,客戶端代碼也不混亂。有很多方式可以實現依賴倒置,比如像AspectJ等的AOP(Aspect Oriented programming)框架使用的位元組碼技術,或Spring框架使用的代理等。

原則6:優先利用組合而非繼承

如果可能的話,優先利用組合而不是繼承。一些人可能會質疑,但我發現,組合比繼承靈活得多。組合允許在運行期間通過設置類的屬性來改變類的行為,也可以通過使用介面來組合一個類,它提供了更高的靈活性,並可以隨時實現。《Effective Java》也推薦此原則。

原則7:里氏代換原則(LSP)

根據該原則,子類必須能夠替換掉它們的基類,也就是說使用基類的方法或函數能夠順利地引用子類對象。LSP原則與單一職責原則和介面分離原則密切相關,如果一個類比子類具備更多功能,很有可能某些功能會失效,這就違反了LSP原則。為了遵循該設計原則,派生類或子類必須增強功能。

原則8:介面分離原則

採用多個與特定客戶類有關的介面比採用一個通用的涵蓋多個業務方法的介面要好。設計介面很棘手,因為一旦釋放介面,你就無法在不中斷執行的情況下改變它。在Java中,該原則的另一個優勢在於,在任何類使用介面之前,介面不利於實現所有的方法,所以單一的功能意味著更少的實現方法。

原則9:針對介面編程,而不是針對實現編程

該原則可以使代碼更加靈活,以便可以在任何介面實現中使用。因此,在Java中最好使用變數介面類型、方法返回類型、方法參數類型等。《Effective Java》 和《head first design pattern》書中也有提到。

原則10:委托原則

該原則最典型的例子是Java中的equals() 和 hashCode() 方法。為了平等地比較兩個對象,我們用類本身而不是客戶端類來做比較。這個設計原則的好處是沒有重覆的代碼,而且很容易對其進行修改。

總之,希望這些面向對象的設計原則能幫助你寫出更靈活更好的代碼。理論是第一步,更重要的是需要開發者在實踐中去運用和體會。

    標簽: Java面向對象
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.申請簽約支付寶移動支付 企業相關信息 企業營業執照等 註冊 2.把支付寶集成到項目中 https://github.com/ganchuanpu/BeijingNews/blob/master/app/src/main/java/com/atguigu/beijingnews/pager/Gov ...
  • 英文文檔: class memoryview(obj) 說明: 1. 函數功能返回記憶體查看對象,實際上是記憶體查看對象(Momory view)的構造函數。 2. 所謂記憶體查看對象,是指對支持緩衝區協議的數據進行包裝,在不需要複製對象基礎上允許Python代碼訪問。 3. Python內置對象中支持緩 ...
  • 話說2015.11.06 ,北京下了第一場雪。16年的今天沒下雪,但是霧霾還是不小的,幫媳婦整理她工作時,出現了下麵的需求,便想到使用PHP來寫程式來進行求解。 【需求】 1. 給出一個平均值X,反過來求出來,得到這個平均值X的三個數X1 ,X2, X3,最大值與最小值的差值要小於0.4(X1-X3 ...
  • 一.概念 1.進程 1.1進程:是一個正在進行中的程式,每一個進程執行都有一個執行順序,該順序是一個執行路徑,或者叫一個控制單元。 1.2線程:就是進程中一個獨立的控制單元,線程在控制著進程的執行,一個進程中至少有一個線程。 1.3舉例java VM: Java VM啟動的時候會有一個進程java. ...
  • 一、jar包 velocity-1.7.jarvelocity-tools-2.0.jarmail.jarspring-context-support-4.0.6.RELEASE.jar 二、配置 代碼 模板mail.vm controllor ...
  • Python簡介 python的創始人為吉多·範羅蘇姆(Guido van Rossum)。1989年的聖誕節期間,吉多·範羅蘇姆為了在阿姆斯特丹打發時間,決心開發一個新的腳本解釋程式,作為ABC語言的一種繼承。 2016年11月TIOBE語言排行榜 甩PHP幾條街 由上圖可見,Python呈上升趨 ...
  • 記錄策略模式,與簡單工廠模式相互結合,降低代碼之間的耦合 案列:超市收銀軟體系統,需求:滿減,打折。。。各種優惠活動 5個類 ...
  • http://www.jxedt.com/wen/xuefei/3174959868757344344.html http://www.jxedt.com/wen/xuefei/3174959869687103511.html http://www.jxedt.com/wen/xuefei/3174 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...