設計模式之禪01單一職責原則

来源:https://www.cnblogs.com/okokabcd/archive/2022/10/29/16840242.html
-Advertisement-
Play Games

為了提高系統吞吐率,也就是提高生產效率,核心觀點如下,系統設計也是如此 在微服務或任何其他基於事件的架構(event-driven-architecture)中,在一些用例中,一個服務可能需要我們對他們自己的本地資料庫進行修改,同時發佈一個事件。然後,該事件會被其他服務所消費。為了擁有一個一致的軟體 ...


單一職責原則

1.1 我是“牛”類,我可以擔任多職嗎

單一職責原則,英文名稱是Single Responsibility Principle,簡稱是SRP,定義是應該有且僅有一個原因引起類的變更。

什麼是類的職責,以及怎麼劃分類的職責?

舉例:rbac模型

image-20221029224918986.png

這個介面設計的存在問題:用戶屬性和用戶行為沒有分開

image-20221029224945983.png

把用戶信息抽取成一個BO(Business Object,業務對象),把行為抽取成一個Biz(Business Logic,業務邏輯),我們面向介面編程,所以產生的UserInfo對象可以當成IUserBO介面使用,也可以錄成IUserBiz介面使用

IUserInfo userInfo = new UserInfo();
IUserBO userBO = (IUserBO)userInfo;
userBO.setPassword("abc");
IUserBiz userBiz = (IUserBiz)userInfo;
userBiz.deleteUser();

在實際使用中,我們更傾向於使用兩個不同的類或介面,如下:

image-20221029230559305.png

1.2 絕殺技,打破你的傳統思維

舉例:電話設計

image-20221029225246280.png

這麼設計的問題是IPhone介面不只有一個職責,分別為:一個是協議管理,一個是數據傳送。

image-20221029225338160.png

這樣設計引起類間耦合過重、類的數量增加,人為地增加了設計的複雜性

image-20221029225351474.png

這樣設計,一個類實現兩個介面,把兩個職責融合在一個類中。

單一職責原則的好處

實現什麼職責都有清晰明確的定義,這樣類的複雜性降低,可讀性提高,可維護性提高

1.3 我單純,所以我快樂

單一職責適用於介面、類,同時也適用於方法。

image-20221029232008493.png

要修改用戶名稱,就調用changeUserName方法;要修改家庭地址,就調用changeHomeAddress方法;要修改單位電話,就調用changeOfficeTel方法。每個方法的職責非常清晰明確,不僅開發簡單,而且日後的維護也非常容易。

1.4 最佳實踐

大部分情況下類設計都是與單一職責相違背的,類的單一職責受到非常多因素的制約,現實你必須去考慮項目工期、成本、人員技術水平、硬體情況、網路情況甚至有時候還要考慮政府政策、壟斷協議等因素。

對於單一職責原則,建議是介面一定要做到單一職責,類的設計儘量做到只有一個原因引起變化。

參考:

  1. 《設計模式之禪》第2版

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用 Notification 可以在系統級別發送頁面外部顯示的桌面通知,即使瀏覽器在後臺運行也可以向用戶發出消息 檢查許可權 發送通知需要用戶授權,通過只讀屬性 Notification.permission 獲取是否有許可權,其屬性值有 granted:用戶已明確授權顯示通知的許可權 denied:用 ...
  • 一、瀏覽器的渲染過程 註意:這個過程是逐步完成的,為了更好的用戶體驗,渲染引擎將會儘可能早的將內容呈現到屏幕上,並不會等到所有的html 都解析完成之後再去構建和佈局 render 樹。它是解析完一部分內容就顯示一部分內容,同時,可能還在通過網路下載其餘內容。 渲染過程解讀如下: 首先解析收到的文檔 ...
  • 一、函數 數的定義有兩種:一為函數的聲明、二為函數表達式-匿名函數 函數聲明 1 function fn(){//需要函數名 2 console.log("函數聲明"); 3 } 4 fn() 函數表達式 1 const fs=function(){//需要定義變數接收 2 console.log( ...
  • Day1 根據自己的垃圾html+css水平寫出了下麵這個頁面: 首先, 首部的超鏈接都能夠鏈接上, 但是不會[更多]的彈出視窗, 右面的天氣/設置/個人也沒有做, 不會怎麼去調用 中間的圖片和搜索欄能夠正常使用, 搜索欄能夠正常搜索. 但是無法水平垂直居中, 而且, 兩個input無法靠近在一起. ...
  • 相信用過vue的小伙伴,肯定被面試官問過這樣一個問題:在vue中動態的引入圖片為什麼要使用require 有些小伙伴,可能會輕蔑一笑:呵,就這,因為動態添加src被當做靜態資源處理了,沒有進行編譯,所以要加上require, 我倒著都能背出來...... emmm... 乍一看好像說的很有道理啊... ...
  • 通過 JavaScript 在瀏覽器中獲取或設置剪貼板中的內容,常用於一鍵複製或使用網頁油猴複製限制文本 使用 ~~execCommand~~ (已棄用) 寫入文本到剪貼板 document.onclick = function() { let text = 'hello world' let do ...
  • 前言 最近無聊看直播,虎牙廣告是真多,還有一堆ghs直播間經常出現在首頁,不想看到這些直播間,於是想辦法屏蔽直播間。 源碼地址 插件地址 演示 下麵先看看未安裝插件之前 虎牙首頁一堆廣告,視頻自動播放 更過分是一堆ghs,噁心人玩意兒的出現在這裡,真是影響觀看體驗 還有左側推薦欄也很煩 安裝之後: ...
  • 1.4 超鏈接 1.4.1 基礎語法 基礎語法: <a href="網頁地址"> </a> 拓展參數: <a href="網頁地址" target="跳轉方式"> </a> | href | 跳轉鏈接地址 | | | | | target | 鏈接打開方式 | 1.4.2 錨鏈接(id參數) 每個標 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...