位元組面試:領域、子域、核心域、通用域和支撐域怎麼劃分?

来源:https://www.cnblogs.com/tangshiye/p/18135241
-Advertisement-
Play Games

領域驅動設計(DDD)裡面有一堆專業術語,比如領域、子域、核心域、通用域、支撐域等等,聽著是不是覺得挺嚇人?別怕,我來帶你輕鬆搞懂它們。 如何理解領域和子域? 領域是指一定的業務範圍或問題域。在解決業務問題時,DDD 會將業務領域進行細分,將問題範圍限定在一定的邊界內,在這個邊界內建立領域模型,用代 ...


領域驅動設計(DDD)裡面有一堆專業術語,比如領域、子域、核心域、通用域、支撐域等等,聽著是不是覺得挺嚇人?別怕,我來帶你輕鬆搞懂它們。

如何理解領域和子域?

領域是指一定的業務範圍或問題域。在解決業務問題時,DDD 會將業務領域進行細分,將問題範圍限定在一定的邊界內,在這個邊界內建立領域模型,用代碼實現這些領域模型,解決相應的業務問題。實際上,核心思想就是分而治之。

領域可以進一步劃分為子域,每個子域對應一個更小的問題域或業務範圍。

DDD 本質上是一種處理複雜領域的設計方法,它試圖通過不斷的細分,使業務從複雜變得簡單,更容易理解,技術實現也更容易。

就像一個公司裡面有不同級別的部門一樣。例如,一家互聯網創業公司,有產品研發部、市場營銷部、客戶服務部等。

領域相當於公司中的一個大部門,比如產品研發部。這個部門負責產品的設計與研發,確定公司的主要業務方向和策略。

子域就像是大部門下的小團隊,例如在產品開發部下,可能會有產品團隊、前端團隊、後端團隊、測試團隊等。每個子域團隊專註於更具體的任務,但都是為了支撐上級部門的目標而設立的。

通過這樣的分級,公司可以確保每個部門、每個團隊甚至每個小組都有明確的責任和目標,讓公司的運作更加有序和高效。

同樣,在DDD中通過劃分領域、子域,可以幫助軟體研發團隊更好地理解和處理複雜的業務需求,每個層級關註不同的細節,但共同協作完成整個系統的開發。這樣不僅提高了開發效率,還能確保軟體能夠準確地滿足業務需求。

如何理解核心域、通用域和支撐域?

在領域劃分的過程中,子域可以根據其重要性和功能屬性劃分為核心域、通用域和支撐域。

核心域決定產品和公司核心競爭力,通用域是被多個子域使用的通用功能域,支撐域是支撐業務的運轉而存在,但不能決定產品和公司核心競爭力,也不包含通用功能。

劃分核心域、支撐域和通用域的主要目標是聚焦關鍵事項,通過領域劃分,區分不同子域在公司內的重要性,讓公司更有效地分配資源和關註度,確保能在激烈的市場競爭中保持優勢。

例如,以電商領域為例,常見的子域包括:商品子域、訂單子域、用戶子域、支付子域、物流子域、客服子域、數據分析子域。

在電商領域,核心域是直接與業務的核心價值和主要收入相關的領域。通常包括:

  • 商品子域:管理商品信息,包括商品展示、分類、搜索和推薦等,是電商平臺的基礎。
  • 訂單子域:處理訂單的創建、修改、查詢和狀態管理等,是完成交易的關鍵環節。
  • 支付子域:處理支付事務,包括支付方式管理、支付狀態跟蹤、支付渠道對接等,是完成交易的另一個關鍵環節。

通用域是支持業務運作的領域,它的能力可以在多個業務領域中使用:

  • 用戶子域:管理用戶信息,包括用戶註冊、登錄、資料編輯等。雖然用戶管理在很多系統中很重要,但在電商系統中,它更多地是支持核心業務流程。

支撐域是指那些為核心域和通用域提供支持的領域,通常涉及基礎設施、運營管理、不直接關聯收入的領域:

  • 物流子域:處理商品的配送,包括物流公司管理、配送狀態跟蹤等,是確保商品成功送達消費者的關鍵環節。
  • 客服子域:提供客戶支持,包括咨詢、投訴處理等,幫助解決用戶在使用過程中遇到的問題。
  • 數據分析子域:分析業務數據,包括用戶行為分析、銷售數據分析等,支持決策制定和業務優化。

總結

領域的核心思想是將問題域逐級細分,降低業務理解和系統實現的複雜度。

核心域、通用域和支撐域則是子域的進一步分類。核心域是產品和公司的核心競爭力,通用域是被多個子域使用的能力,支撐域是支撐業務運轉的領域。這種劃分有助於理解和處理複雜的業務需求,提高開發效率,確保軟體滿足業務需求。

本文來自博客園,作者:架構師湯師爺,轉載請註明原文鏈接:https://www.cnblogs.com/tangshiye/p/18135241


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

-Advertisement-
Play Games
更多相關文章
  • iOS系統崩潰的捕獲 相信大家在開發iOS程式的時候肯定寫過各種Bug,而其中最為嚴重的Bug就是會導致崩潰的Bug(一般來說妥妥的P1級)。在應用軟體大大小小的各種異常中,崩潰確實是最讓人難以接受的行為。畢竟崩潰意味著用戶將丟失應用程式運行中的所有上下文環境,丟失其所有未保存的數據,會帶給用戶最糟 ...
  • 隨著互聯網技術的迅速發展,用戶對網頁的載入速度和交互體驗有了更高的期待。作為開發者,我們常常需要在伺服器端渲染(SSR)與客戶端渲染(CSR)之間做出選擇。這兩種渲染方式各有特點,適用於不同的場景和需求。今天,就讓我們一起來探索SSR和CSR的世界,幫助你為你的應用選擇最合適的渲染策略。 什麼是渲染 ...
  • 錨點鏈接 <a href="#Cat"></a> 點擊這個鏈接將為跳轉到這個頁面上id為Cat的頁面 利用這個功能,我們可以實現給一個頁面插眼的功能。 比如我們想建一個動物園的網站 <!-- 動物園導航欄--> <header> <ul> <li><a href="cat">Cats</a></li ...
  • 關於微信小程式轉發&保存圖片 已經好多年沒寫博客了,最近使用在用uniapp開發一個移動版管理後臺,記錄下自己踩過的一些坑 微信小程式圖片轉發保存簡單說明 微信小程式圖片轉發保存,依賴小程式的轉發api—— wx.showShareImageMenu(Object object) 通過調用這個api ...
  • 0x01 概述 API 是一些預先定義的函數,提供應用程式與開發人員基於某軟體或硬體訪問一組常式的能力 Web APIs 是 W3C 組織的標準,是 JS 獨有的部分 Web API 是瀏覽器提供的一套操作瀏覽器功能和頁面元素的 API,即 DOM 與 BOM 0x02 DOM (1)簡介 文檔對象 ...
  • 1、首先構造函數為中心 function Person() { } var p = new Person(); console.log('Person::', p) console.log(p.constructor Person) 列印如下: 可以看出構造函數通過new得到實例,實例可以通過【co ...
  • 今天我為大家帶來新的作品,iOS17桌面組件神器(Scriptable)原創腳本,精美作品分享!喜歡的話就點關註吧!更多腳本正在路上... * script : ONE-Progress.js * version : 1.0.0 * author : Nicolas-kings * date : 2 ...
  • 適配器模式(Adapter Pattern) 結構型設計模式,見名知意,就是兩個不相容的介面之間的橋梁。它結合了兩個獨立介面的功能。 主要解決:常常要將一些"現存的對象"放到新的環境中,而新環境要求的介面是現對象不能滿足的。 關鍵代碼:適配器繼承或依賴已有的對象,實現想要的目標介面。 優點: 1、可 ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...