聊聊 Service 命名与设计
點擊上方“朱小廝的博客”,選擇“設為星標”
后臺回復"書",獲取
后臺回復“k8s”,可領取k8s資料
Service 類到底是什么含義?我相信如果碰到一個叫 SomethingService 的類,沒法馬上明白它到底起什么作用。
說實話,我們都很困惑。
經過多年的專業開發,在大量的代碼中游走,有一點是顯而易見的,開發人員不太擅長給事物命名。
作為一個菜鳥開發者,我知道當看到 SomeService 或 WhateverManager 類,或者是 WhatevsManagerService 時,你都會不知所措或疑惑不解。
Class 命名就像工作頭銜
BD?實際是一個銷售人員。Social Media 專家?可能是 3 周學會如何在 Instagram 上發布貓咪照片。軟件工程師?實際上是堆砌代碼的碼農。
工作頭銜和工作角色有時候不掛鉤,我們更喜歡把頭銜弄得比角色更花哨。
Class 命名也是如此。
服務(service)類
任何以 Service 為后綴的代碼基本上都是一個邏輯垃圾箱。任何添加到程序中的新功能,最后總是以某種服務類的方式來實現。
一個服務類需要大量的構造函數參數,使得測試起來非常麻煩。要測試一個新方法 GetUserCount()?可能需要 mock 7 個完全不相關的類來實例化這個服務類。
如果 GetUserCount() 只依賴于服務類中的一個構造函數參數,那么最好把它移到自己的類中。這樣一來,你就有一個非常簡單的類,只有一個構造函數參數。
當然,單獨的 GetUserCount 類看起來不是那么酷,但至少你知道它到底是做什么的。
測試變得輕而易舉。
Manager 類
你很可能見過類似 UserManager 這樣的類,它管理用戶。
像服務類一樣,它們也是邏輯垃圾箱。但是有一點區別。如果說服務類是一個普通的垃圾箱,那么 Manager 類就像一個紙板垃圾箱,它更特殊一點。
你會面臨和服務類一樣的處理單元測試的問題。在做最微小的操作之前,你需要 mock 一大堆東西。
Util 類和 Helper 類
"我們不知道把這些代碼塞在哪里好,所以就弄了一個 Util 類"。
這些都是煩人的東西。關于這一點,沒有什么好說的了。
怎么破?
很簡單。給出與職責相匹配的合適名稱。把一個類命名為GetUser,并且只有一個方法,這并不丟人。實現也簡單,每個人都知道它是做什么的。容易進行單元測試。
停止代碼膨脹,簡化這些類。比如,構建只有一個方法的類。
關于作者:
Nicklas Millard 是一家快速發展中的銀行擔任軟件工程師,負責構建關鍵任務的金融服務基礎設施。
此前,他曾是 Big4 高級技術顧問,為商業客戶和政府機構開發軟件。
他的 LinkedIn:https://www.linkedin.com/in/nicklasmillard/
英文原文:
https://medium.com/datadriveninvestor/the-true-meaning-of-service-and-manager-class-names-d09a08731fd9
想知道更多?掃描下面的二維碼關注我
后臺回復"技術",加入技術群
后臺回復“k8s”,可領取k8s資料
【精彩推薦】
原創|OpenAPI標準規范
如此簡單| ES最全詳細使用教程
ClickHouse到底是什么?為什么如此牛逼!
原來ElasticSearch還可以這么理解
面試官:InnoDB中一棵B+樹可以存放多少行數據?
微服務下如何解耦?對于已經緊耦合下如何重構?
如何構建一套高性能、高可用、低成本的視頻處理系統?
架構之道:分離業務邏輯和技術細節
星巴克不使用兩階段提交
點個贊+在看,少個 bug?????
總結
以上是生活随笔為你收集整理的聊聊 Service 命名与设计的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 好文推荐 | 分布式锁用Redis好,还
- 下一篇: 阿里技术专家:数据一致性检测的应用场景与