PHP 雜談《重構-改善既有代碼的設計》之二 對象之間搬移特性PHP 雜談《重構-改善既有代碼的設計》之 重新組織你的函數

來源:互聯網
上載者:User
 思維導圖 

 

索引:

Ø Move Method(搬移函數)Ø Move Field (搬移範圍)Ø Extract Class (提煉類)Ø Inline Class (將類內聯化,就是把當前的類合并到其他類中)Ø Hide Delegate (隱藏委託關係)Ø Remove Middle Man ( 移除中間人)Ø Introduce Foreign Method (引入外加函數)Ø Introduce Local Extension (引入本地擴充)  介紹  承接上文PHP 雜談《重構-改善既有代碼的設計》之 重新組織你的函數 ,繼續說重構方面的內容。    專業術語 delegate:委託encapsulate:封裝introduce:引入wrapper:覆蓋  前言 ”決定把責任放在哪裡“——運用重構改變原先的設計。 

解釋:

  1、Class承擔過多而臃腫不堪——Extract Class將一部分責任分離出去。

  2、Class沒有承擔足夠多的責任,不再有單獨存在的理由——Inline Class將它融入另一個Class。

  3、Class使用另一個Class——Hide Delegate隱藏關係。

  4、承接(3),如果Client通過Middle Man 調用很多的Delegate Class的函數(這裡只是簡單調用,只做跳轉,而Middle Man沒有做太多的商務邏輯,如10個Delegate Class中的Method對應10個Middle Man的Method)——Remove Middle Man,直接使用Delegate Class,可以部分使用Delegate Method。

 

 Move Method 如果一個類中的方法與另一個類有很多的交流,那麼我們就 在另一個類中建立一個有類似功能的新函數,將舊函數變成一個單純的Delegating Method, 或是將舊函數移除。

 

類圖:

 

動機:

  1、如果一個類與另一個類有高度耦合,我就會Move Method。——class更簡單,更乾淨利落的實現系統交付的任務。

  2、移動一些範圍,就要檢查是否使用另一個類的次數必使用所駐對象的次數還多。

 Move Field 狀況:你的class中的field被另一個class更多的用到。那麼在另一個class裡建立new field,修改舊的field。 

  Extract Class 狀況:一個類做了兩個類做的事,那麼建立一個新Class,將相關的Field和Method從舊Class移到新Class。

 

 

 Inline Class 狀況:你的某個Class沒有做太多事情(沒有承擔足夠責任),那麼將Class的所有特性搬移到另一個Class中,然後移除原Class。動機:Inline Class與Extract Class相反。——把Extract Class例子反過去,因為PhoneNumber只用作讀取code和number。  Hide Delegate 狀況:客戶直接調用Server Object的Delegate Class的Method,那麼在Server端建立客戶所需的函數Method,用以隱藏委託關係。  學過對象技術的人都知道,雖然php允許你將field聲明為public,但你還應該隱藏field(private)。隨著經驗日漸豐富,有更多值得封裝的東西。 看下面一個例子:

  $person->getDepartment()->getManager()明顯揭露了,要想找到Xiaocai的領導,必須要經過department,所以我們要做的事隱藏department。——可以減少耦合性。 

 

 Remove Middle Man 狀況:如果某個Class做了過多的Simple Delegate,那麼我們就直接調用Delegate Class。動機:在Hide Delegate中的例子裡當Department有更多新方法的時候,我們為了Hide Delegate,就要必須在Person裡添加相應的方法做Delegate之用。這時候的Person完全變成了一個Middle Man,此時我們就應該直接調用Delegate Class——Department。 重構的意義就在於:你永遠不必說對不起,只要你把出問題的地方修補好就行了。   

 

 Introduce Foreign Method 狀況:有一個類Client需要使用的類PreviousEnd中一個額外函數,但你無法修改這個類PreviousEnd,那麼你就在Client中建立一個函數,並以一個PreviousEnd實體做為參數。

 

 Introduce Local Extention 狀況:你的Class需要一些額外函數,但你不能修改當前的類,那麼建立一個新Class,使它包含這些函數。使用Subclass 或 Wrapper。——這個一般用於你無法修改源碼的情況下使用。  拿上面Introduce Foreign Method例子來說

使用Subclass方法 

或使用Wrapper

 

  總結 需要注意一下,“Extract Class”和“Inline Class”,”Hide Delegate“和”Remove Middle Man",都是相反的過程,具體理解,可以看前言中的那張流程圖。 “Hide Delegate"我們常用於使用少量的”Delegate Method“的時候,而”Remove Middle Man“,用於調用很多”Delegate Method“的時候,我們可以直接使用Delegate Class,進行調用,而有的Delegate Method我們視情況保留一部分。 “Extract Class”和“Inline Class”,"Extract Class"經常用於承擔那過多責任而變得臃腫不堪的Class中,而“Inline Class”經常用於當前的這個類”太不負責的“時候使用。——我個人是寧願“Extract Class”,也不願“Inline Class”。 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.