學習筆記三

Code Review

今天在圓老師的帶領下,進行了一次Code Review。盡管之前也知道一些Code Smell,然鵝,在限時訓練的時候,就顧不上那么多了,各種隨意,直接導致代碼中有很多需要重構的地方。

問題集中體現在以下幾個方面:

  1. Test setup(在多個測試中都new了同一個對象,所以應該把這個對象提到@Before中,減少冗余代碼)
  2. 移動方法到正確的類中(將方法根據對應的功能放在對應的類中,不要在一個類中寫與該類無關的方法)
  3. 空行/格式化(寫完代碼記得要養成格式化的習慣,在適當的地方加上空行,幫助理清代碼結構)
  4. 類名是名詞,方法名用動詞
  5. 重構一次運行一次測試(每次重構都要運行測試,來檢驗這次重構是否正確,如果正確,刪除掉以前的代碼)
  6. 消除重復代碼
  7. 分離職責(每個方法都實現自己對應的職責,不要一個方法實現太多職責)
  8. 去除不必要臨時變量

這么多問題的存在,證明,還是沒有培養出好的編程習慣,以后一定要控制我自己~減少 Code Smell 的發生,培養良好的編程習慣,從我做起。

三層架構

三層架構是一個分層式的軟件體系架構設計理念,適用于所有項目。

軟件設計的三層架構.png

1. 表示層(表示層一般使用下面??這幾種語言框架)

- JSP
- JS
- Angular
- Reactive 

作用:用于顯示數據和接收用戶輸入的數據,為用戶提供一種交互式操作的界面。主要對用戶的請求接受,以及數據的返回,為客戶端提供應用程序的訪問。

2. 業務邏輯層(同層之間可以自己調用,這一層是一些服務,服務之間可以互相調用)

作用:主要負責對數據層的操作。也就是說把一些數據層的操作進行組合。用戶輸入的數據通過業務邏輯層的處理發給數據層,數據層返回的數據通過業務邏輯層發送給界面展示。

業務邏輯層無疑是系統架構中的核心部分。它處于表示層和數據訪問層中間,起到了數據交換中承上啟下的作用

3. 持久層(或數據訪問層)

作用:主要完成各個對數據文件的操作,是對數據庫的操作,具體為業務邏輯層或表示層提供數據服務。

三層架構的特點:

  1. 低層不能調用上層。
  2. 同層之前可以互相調用,但是,持久層和展示層之間不能互相調用。

三層架構的優點:

  1. 開發人員可以只關注整個結構中的某個一層。
  2. 實現高內聚低耦合的思想。
  3. 降低層與層之間的依賴。
  4. 結構更加明確。
  5. 方便后期維護。

MVC(Model-View-Controller)

MVC 把用戶界面獨立到一些文件中(Views),把一些和用戶交互的程序邏輯(Controller)單獨放在一些文件中,在 Views 和 Controller 中傳遞數據使用一些專門封裝數據的實體對象,這些對象,統稱為Models。

mvc.png

三層架構和 MVC 的區別

MVC 屬于展示層的一種架構模式,和三層架構沒有必然關系。

三層架構是系統架構,屬于宏觀的解決方案??赡軙枰N不同職能的程序員來維護,每個人可以專注于自己擅長的模塊,分別進行開發。
MVC 是設計模式,屬于微觀的解決方案。是同一個程序員可以接觸的東西,目的是為了讓HTML代碼和業務邏輯代碼分開,讓代碼看起來更加清晰,便于開發。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容