重构改善既有代码的设计是php,下篇 |《重构 改善既有代码的设计—笔记》| PHP 技术论坛...
循環語句
我們常用到循環,現在有了新的函數,例如 php 的 foreach(),java 的管道操作(如 filter 和 map),可以幫助我們更快地處理數據。
冗贅的元素
給代碼增加結構(如類和函數)可以支持變化、促進復用。但可能最初在編寫類或函數時覺得以后可能會變得更大、更復雜,結果卻越變越小,最后剩一個函數,那么這時便要考慮將其歸并到其他地方了。
夸夸其談通用性
如果你總是覺得“總有一天需要做這事”,然后企圖以各種各式各樣的鉤子和特殊情況來處理一些事情,那么壞代碼就出現了,這樣做往往造成系統更加難理解和維護。
應該遵循這樣的原則:如果所有的裝置都會被用到,那就值得那么做,如果用不到,就不值得。
臨時字段
有時某個類的某個字段僅為某種特定情況而設,這樣的代碼不容易理解,因為你通常認為對象在所有時候都需要它的所有字段,在字段未被使用的情況下猜測當初設置它的目的,會讓你很疑惑。
最好是將這個字段和與這個字段相關的代碼集中在一塊。
過長的消息鏈
如果你看到用戶向一個對象請求另一個對象,然后再向后者請求另一個對象,接著繼續請求另一個對象……這就是消息鏈。這意味著代碼緊耦合,一旦對象間的關系發生變化,那么客戶端就得做出相應的修改。
通常是將調用對象的代碼用函數封裝起來,這樣客戶端不需要知道對象間的關系,只需要知道調用這個函數就可以返回最終需要的對象。
中間人
前面消息鏈講到的封裝如果使用不恰當,可能會造成過度使用,這時應該移除中間人(封裝的函數),直接與真正負責的對象打交道。
內幕交易
模塊之間大量交換數據,增加模塊間的耦合,應當盡量減少這種情況。
過大的類
如果單個類做太多事情,往往會出現很多字段與重復代碼。最好是將相關的變量提到新類,或者提煉相同的代碼到函數去。
異曲同工的類
當存在不同的類卻在做同樣的事時,可以通過搬移函數到其中一個類,逐漸消滅另一個類。
純數據類
純數據類是指除了擁有一些字段和訪問這些字段的函數之外,便沒有其他用處了。可以嘗試找出這些函數被調用的地點,盡量將調用行為搬移到純數據類來。
被拒絕的遺贈
子類應該繼承超類的函數和數據,如果存在子類不想繼承的,說明繼承體系設計錯誤。這時可以新建一個兄弟類,將不需要的函數推給兄弟類,這樣超類就只持有子類共享的東西。
子類不想繼承超類的接口與不想實現超類的接口是兩回事,既然不想繼承,那就直接畫清界限吧。
注釋
如果你發現一段代碼有著長長的注釋時,說明這段代碼難以理解,此時需要將代碼搬移到新函數,并為它取個說明這段代碼用途的名字。
總結
以上是生活随笔為你收集整理的重构改善既有代码的设计是php,下篇 |《重构 改善既有代码的设计—笔记》| PHP 技术论坛...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php 查询数据库 刷新,这个每次刷新都
- 下一篇: php主机转发ipv6,php实现ipv