国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 10個Java程序員熟悉的面向對象設計原則

10個Java程序員熟悉的面向對象設計原則

2020-08-31 14:12qq_37904909 Java教程

這篇文章主要為大家詳細介紹了Java程序員應當知道的10個面向對象設計原則,具有一定的參考價值,感興趣的小伙伴們可以參考一下

面向對象設計原則是OOPS編程的核心, 但我見過的大多數Java程序員熱心于像Singleton (單例) 、 Decorator(裝飾器)、Observer(觀察者) 等設計模式,而沒有把足夠多的注意力放在學習面向對象的分析和設計上面。學習面向對象編程像“抽象”、“封裝”、“多態”、“繼承” 等基礎知識是重要的,但同時為了創建簡潔、模塊化的設計,了解這些設計原則也同等重要。我經常看到不同經驗水平的java程序員,他們有的不知道這些OOPS 和SOLID設計原則,有的只是不知道一個特定的設計原則會帶來怎樣的益處,甚至不知道在編碼中如何使用這些設計原則。

(設計原則)底線是永遠追求高內聚、低耦合的編碼或設計。 Apache 和 Sun的開源代碼是學習Java和OOPS設計原則的良好范例。它們向我們展示了,設計原則在Java編程中是如何使用的。Java JDK 使用了一些設計原則:BorderFactory類中的工廠模式、Runtime類中的單例模式、java.io 類中的裝飾器模式。順便說一句,如果您真的對Java編碼原則感興趣,請閱讀Joshua Bloch 的Effective Java,他編寫過Java API。我個人最喜歡的關于面向對象設計模式的是Kathy Sierra的Head First Design Pattern(深入淺出設計模式),以及其它的關于深入淺出面向對象分析和設計。這些書對編寫更好的代碼有很大幫助,充分利用各種面向對象和SOLID的設計模式。

雖然學習設計模式(原則)最好的方法是現實中的例子和理解違反設計原則帶來的不便,本文的宗旨是向那些沒有接觸過或正處于學習階段的Java程序員介紹面向對象設計原則。我個人認為OOPS 和SOLID設計原則需要有文章清楚的介紹它們,在此我一定盡力做到這點,但現在請您準備瀏覽以下設計模式(原則) :)
DRY – Don't repeat yourself

我們第一個面向對象設計原則是:DRY ,從名稱可以看出DRY(don't repeat yourself)意思是不寫重復代碼,而是抽象成可復用的代碼塊。如果您有兩處以上相同的代碼塊,請考慮把它們抽象成一個單獨的方法;或者您多次使用了硬編碼的值,請把它們設置成公共常量。這種面向對象設計原則的優點是易于維護。重要的是不要濫用此原則,重復不是針對代碼而是針對功能來說。它的意思是,如果您使用通用代碼來驗證OrderID和SSN,這并不意味著它們是相同的或者他們今后將保持不變。通過把通用代碼用于實現兩種不同的功能,或者您把這兩種不同的功能密切地聯系在一起;當您的OrderID格式改變時,您的SSN驗證代碼將會中斷。所以要當心這種耦合,而且不要把彼此之間沒有任何關系卻類似的代碼組合在一起。

封裝經常修改的代碼

Encapsulate What Changes

在軟件領域永遠不變的是“變化”,所以把您認為或懷疑將來要被修改的代碼封裝起來。這種面向對象設計模式的優點是:易于測試和維護恰當封裝的代碼。如果您在用Java編程,那么請遵守以下原則:變量和方法的訪問權限默認設置為私有,并且逐步放開它們的訪問權限,例如從“private”到“protected ”、“not public”。Java中的一些設計模式使用了封裝,工廠設計模式就是一個例子,它封裝了創建對象的代碼而且提供了以下靈活性:后續生成新對象不影響現有的代碼。

打開/關閉設計原則

OpenClosed Design Principle

類、方法/函數應當是對擴展(新功能)開放,對修改閉合。這是另外一個優雅的SOLID 設計原則,以防止有人修改通過測試的代碼。理想情況下假如您添加了新功能,那么您的代碼要經過測試,這就是打開/關閉設計原則的目標。順便說一句,SOLID中的字母“O”指的是打開/關閉設計原則。

單一職責原則

Single Responsibility Principle(SRP)

單一職責原則是另外一個SOLID設計原則,SOLID中的字母“S”指的就是它。按照SRP,一個類修改的原因應當有且只有一個,或者一個類應當總是實現單一功能。如果您在Java中的一個類實現了多個功能,那么這些功能之間便產生了耦合關系;如果您修改其中的一個功能,您有可能就打破了這種耦合關系,那么就要進行另一輪測試以避免產生新的問題。

依賴注入/反轉原則

Dependency Injection or Inversion principle

不要問框架的依賴注入功能將會給你帶來什么益處,依賴注入功能在spring框架里已經很好的得到了實現,這一設計原則的優雅之處在于:DI框架注入的任何一個類都易于用模擬對象進行測試,并且更易于維護,因為創建對象的代碼在框架里是集中的而且和客戶端代碼是隔離的。有多種方法可以實現依賴注入,例如使用字節碼工具,其中一些AOP(面向切面編程)框架如切入點表達式或者spring里使用的代理。想對這種SOLID設計原則了解更多,請看IOC 和 DI設計模式中的例子。 SOLID中的字母“D”指的就是這種設計原則。

優先使用組合而非繼承

Favor Composition over Inheritance

如果可以的話,要優先使用組合而非繼承。你們中的一些人可能為此爭論,但我發現組合比繼承更有靈活性。組合允許在運行時通過設置屬性修改一個類的行為,通過使用多態即以接口的形式實現類之間的組合關系,并且為修改組合關系提供了靈活性。甚至 Effective Java也建議優先使用組合而非繼承。

里氏替換原則

Liskov Substitution Principle LSP

根據里氏替換原則,父類出現的地方可以用子類來替換,例如父類的方法或函數被子類對象替換應該沒有任何問題。LSP和單一職責原則、接口隔離原則密切相關。如果一個父類的功能比其子類還要多,那么它可能不支持這一功能,而且也違反了LSP設計原則。為了遵循 LSP SOLID設計原則,派生類或子類(相對父類比較)必須增強功能,而非減少。SOLID中的字母“L”指的就是 LSP設計原則。

接口隔離原則

接口隔離原則指,如果不需要一個接口的功能,那么就不要實現此接口。這大多在以下情況發生:一個接口包含多種功能,而實現類只需要其中一種功能。接口設計是一種棘手的工作,因為一旦發布了接口,您就不能修改它否則會影響實現該接口的類。在Java中這種設計原則的另一個好處是:接口有一個特點,任何類使用它之前都要實現該接口所有的方法,所以使用功能單一的接口意味著實現更少的方法。

編程以接口(而非實現對象)為中心

編程總是以接口(而非實現對象)為中心,這會使代碼的結構靈活,而且任何一個新的接口實現對象都能兼容現有代碼結構。所以在Java中,變量、方法返回值、方法參數的數據類型請使用接口。這是許多Java程序員的建議, Effective Java 以及 head first design pattern 等書也這樣建議。

代理原則

不要期望一個類完成所有的功能,可以適當地把一些功能交給代理類實現。代理原則的典范是:Java 中的equals() 和 hashCode() 方法。為了比較兩個對象的內容是否相同,我們讓用于比較的類本身完成對比工作而非它們的調用方。這種設計原則的好處是:沒有重復編碼而且很容易修改類的行為。

總結

以上所有面向對象的設計原則可以幫助您寫出靈活、優雅的代碼:具有高內聚低耦合的代碼結構。理論只是第一步,更重要的是我們要習得一種能力去發現什么時候使用這些設計原則。去發現我們是否違反了什么設計原則和影響了代碼的靈活性,但是世界上沒有什么是完美的,我們解決問題時不能總去使用設計模式和設計原則,它們大多用于有較長維護周期的大型企業項目。

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 天天操夜夜爽 | 草久在线观看 | 国产成人精品久久二区二区91 | 国产在线视频一区 | 日韩不卡一二三 | 久久久久久国产 | 中文字幕亚洲精品 | 亚洲国产精品欧美一二99 | 黄色免费在线视频 | 伊人逼逼| 黄色在线免费看 | 久久波多野结衣 | 亚洲成人一区二区 | 免费av电影观看 | 中文字幕日韩在线视频 | 91嫩草精品 | 国产麻豆一区二区三区 | 影音先锋男 | 性色综合 | 欧美成人自拍 | 亚洲成人精品久久久 | 成人乱人乱一区二区三区 | 午夜影院在线观看 | 中文字幕精品视频 | 韩国精品一区 | 国产精品无码永久免费888 | 欧美亚洲一 | 国内精品一区二区 | 可以在线观看的av网站 | 精品久久99| 中文字幕国产日韩 | 天天操综合网 | 国产成人精品一区二 | 黄色网页在线 | 美女h视频| 一区二区久久 | 欧美视频二区 | 激情网站免费观看 | av网站免费在线观看 | 亚洲在线一区 | 一本大的之伊人 |