Code Review
今天在圓老師的帶領下,進行了一次Code Review。盡管之前也知道一些Code Smell,然鵝,在限時訓練的時候,就顧不上那么多了,各種隨意,直接導致代碼中有很多需要重構的地方。
問題集中體現在以下幾個方面:
- Test setup(在多個測試中都
new
了同一個對象,所以應該把這個對象提到@Before
中,減少冗余代碼) - 移動方法到正確的類中(將方法根據對應的功能放在對應的類中,不要在一個類中寫與該類無關的方法)
- 空行/格式化(寫完代碼記得要養成格式化的習慣,在適當的地方加上空行,幫助理清代碼結構)
- 類名是名詞,方法名用動詞
- 重構一次運行一次測試(每次重構都要運行測試,來檢驗這次重構是否正確,如果正確,刪除掉以前的代碼)
- 消除重復代碼
- 分離職責(每個方法都實現自己對應的職責,不要一個方法實現太多職責)
- 去除不必要臨時變量
這么多問題的存在,證明,還是沒有培養出好的編程習慣,以后一定要控制我自己~減少 Code Smell 的發生,培養良好的編程習慣,從我做起。
三層架構
三層架構是一個分層式的軟件體系架構設計理念,適用于所有項目。
軟件設計的三層架構.png
1. 表示層(表示層一般使用下面??這幾種語言框架)
- JSP
- JS
- Angular
- Reactive
作用:用于顯示數據和接收用戶輸入的數據,為用戶提供一種交互式操作的界面。主要對用戶的請求接受,以及數據的返回,為客戶端提供應用程序的訪問。
2. 業務邏輯層(同層之間可以自己調用,這一層是一些服務,服務之間可以互相調用)
作用:主要負責對數據層的操作。也就是說把一些數據層的操作進行組合。用戶輸入的數據通過業務邏輯層的處理發給數據層,數據層返回的數據通過業務邏輯層發送給界面展示。
業務邏輯層無疑是系統架構中的核心部分。它處于表示層和數據訪問層中間,起到了數據交換中承上啟下的作用
3. 持久層(或數據訪問層)
作用:主要完成各個對數據文件的操作,是對數據庫的操作,具體為業務邏輯層或表示層提供數據服務。
三層架構的特點:
- 低層不能調用上層。
- 同層之前可以互相調用,但是,持久層和展示層之間不能互相調用。
三層架構的優點:
- 開發人員可以只關注整個結構中的某個一層。
- 實現高內聚低耦合的思想。
- 降低層與層之間的依賴。
- 結構更加明確。
- 方便后期維護。
MVC(Model-View-Controller)
MVC 把用戶界面獨立到一些文件中(Views),把一些和用戶交互的程序邏輯(Controller)單獨放在一些文件中,在 Views 和 Controller 中傳遞數據使用一些專門封裝數據的實體對象,這些對象,統稱為Models。
mvc.png
三層架構和 MVC 的區別
MVC 屬于展示層的一種架構模式,和三層架構沒有必然關系。
三層架構是系統架構,屬于宏觀的解決方案??赡軙枰N不同職能的程序員來維護,每個人可以專注于自己擅長的模塊,分別進行開發。
MVC 是設計模式,屬于微觀的解決方案。是同一個程序員可以接觸的東西,目的是為了讓HTML代碼和業務邏輯代碼分開,讓代碼看起來更加清晰,便于開發。