自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

架構(gòu)師之路之業(yè)務(wù)領(lǐng)域建模

開發(fā) 架構(gòu)
領(lǐng)域模型是對(duì)領(lǐng)域內(nèi)的概念類或現(xiàn)實(shí)世界中對(duì)象的可視化表示。又稱概念模型、領(lǐng)域?qū)ο竽P?、分析?duì)象模型。它專注于分析問題領(lǐng)域本身,發(fā)掘重要的業(yè)務(wù)領(lǐng)域概念,并建立業(yè)務(wù)領(lǐng)域概念之間的關(guān)系。

 [[396130]]

本文轉(zhuǎn)載自微信公眾號(hào)「JAVA日知錄」,作者單一色調(diào)。轉(zhuǎn)載本文請(qǐng)聯(lián)系JAVA日知錄公眾號(hào)。

領(lǐng)域模型的概念及作用

領(lǐng)域模型是對(duì)領(lǐng)域內(nèi)的概念類或現(xiàn)實(shí)世界中對(duì)象的可視化表示。又稱概念模型、領(lǐng)域?qū)ο竽P?、分析?duì)象模型。它專注于分析問題領(lǐng)域本身,發(fā)掘重要的業(yè)務(wù)領(lǐng)域概念,并建立業(yè)務(wù)領(lǐng)域概念之間的關(guān)系。概念比較深?yuàn)W,其實(shí)說白了就是我們把基于對(duì)業(yè)務(wù)的理解畫成一個(gè)類圖,并畫出這些類之間的關(guān)系(面向?qū)ο?。

領(lǐng)域模型可以整理業(yè)務(wù)中的概念以及關(guān)系,幫助團(tuán)隊(duì)中的成員對(duì)業(yè)務(wù)的理解保持一致,往后可以指導(dǎo)數(shù)據(jù)庫設(shè)計(jì)、系統(tǒng)功能設(shè)計(jì)、指導(dǎo)開發(fā)。在整個(gè)系統(tǒng)建設(shè)周期能起到 上接需求,下承開發(fā) 的作用。

那既然領(lǐng)域模型如此重要,我們是不是要在類圖中盡可能的展示對(duì)象的屬性和方法,以便更好的指導(dǎo)后續(xù)的開發(fā)設(shè)計(jì)。

恰恰相反,我們?cè)诮5臅r(shí)候不要將注意力集中在屬性或行為上,應(yīng)該擺脫這些細(xì)枝末節(jié),抓住領(lǐng)域?qū)ο蠖x的最基本特征,只需要體現(xiàn)對(duì)象模型的重要概念。如果細(xì)節(jié)過多很容易產(chǎn)生 ”只見樹木,不見森林“ 的現(xiàn)象。

下面我們看一個(gè)簡(jiǎn)化后的報(bào)銷業(yè)務(wù)的領(lǐng)域模型,加深一下印象。

完成一個(gè)領(lǐng)域模型建模,主要需要做兩件事:

  1. 定義類的關(guān)鍵屬性和關(guān)鍵行為;
  2. 定義類與類之間的關(guān)聯(lián)關(guān)系。

定義類的屬性和行為

定義類的屬性和行為比較簡(jiǎn)單,用設(shè)計(jì)工具拖一個(gè)class即可,這里只需要注意一下屬性和行為的訪問權(quán)限。

  1. - 表示private   
  2. # 表示protected  
  3. ~ 表示default,也就是包權(quán)限   
  4. + 表示public 

定義類與類之間的交互關(guān)系

在UML類圖中,定義了六種類之間的關(guān)系,他們分別是:泛化(Generalization), 實(shí)現(xiàn)(Realization),關(guān)聯(lián)(Association),聚合(Aggregation),組合(Composition),依賴(Dependency)。關(guān)系比較多,而且有些還比較相近,比如聚合和組合,接下來我們逐漸講解:

泛化(Generalization)

介紹:

泛化(Generalization)表示類與類之間的繼承關(guān)系,接口與接口之間的繼承關(guān)系。

圖例:

使用 空心三角形+實(shí)線 表示。

代碼實(shí)現(xiàn):

  1. public class A { 
  2.    
  3.  
  4. public class B extends A { 
  5.    

實(shí)現(xiàn)(Realization)

介紹:

實(shí)現(xiàn)(Realization)表示一個(gè)class類實(shí)現(xiàn)interface接口(可以是多個(gè))的功能。

圖例:

使用 空心三角形+虛線 表示。

代碼實(shí)現(xiàn):

  1. public interface A { 
  2.    
  3.  
  4. public class B implements A { 
  5.    

聚合(Aggregation)

介紹:

聚合(Aggregation)表示一種弱的 ‘擁有’ 關(guān)系,即has-a的關(guān)系,體現(xiàn)的是A對(duì)象可以包含B對(duì)象,B類生命周期可以不依賴A類對(duì)象的生命周期, 也就是說可以單獨(dú)銷毀A類對(duì)象而不影響B(tài)類對(duì)象,比如課程與學(xué)生之間的關(guān)系。

圖例:

使用 空心的菱形+實(shí)線箭頭 表示。

代碼實(shí)現(xiàn):

  1. public class A { 
  2.     private B b; 
  3.     public A(B b){ 
  4.         this.b = b; 
  5.     } 

組合(Composition)

介紹:

組合(Composition)表示一種強(qiáng)的 ‘擁有’ 關(guān)系,即contains-a的關(guān)系,體現(xiàn)的是A對(duì)象包含B對(duì)象,B類生命周期依賴A類對(duì)象的生命周期,B類對(duì)象不可單獨(dú)存在,比如鳥與翅膀之間的關(guān)系。

圖例:

使用 實(shí)心的菱形+實(shí)線箭頭 表示,還可以使用連線兩端的數(shù)字表示某一端有幾個(gè)實(shí)例。

代碼實(shí)現(xiàn):

  1. public class A { 
  2.     private B b; 
  3.     public A () { 
  4.         this.b = new B(); 
  5.     } 

關(guān)聯(lián)(Association)

介紹:

關(guān)聯(lián)(Association)是一種非常弱的關(guān)系,包含聚合、組合兩種關(guān)系。對(duì)于兩個(gè)相對(duì)獨(dú)立的對(duì)象,當(dāng)一個(gè)對(duì)象負(fù)責(zé)構(gòu)造另一個(gè)對(duì)象的實(shí)例,或者依賴另一個(gè)對(duì)象的服務(wù)時(shí),這兩個(gè)對(duì)象之間主要體現(xiàn)為依賴關(guān)系。具體到代碼層面,如果B類是A類的成員變量,那么B類和A類就是關(guān)聯(lián)關(guān)系。

圖例:

使用實(shí)線箭頭表示。

代碼實(shí)現(xiàn):

  1. public class A { 
  2.     private B b; 
  3.     public A(B b){ 
  4.         this.b = b; 
  5.     } 

或者

  1. public class A { 
  2.     private B b; 
  3.     public A () { 
  4.         this.b = new B(); 
  5.     } 

依賴(Dependency)

介紹:

依賴(Dependency) 是比關(guān)聯(lián)關(guān)系更加弱的關(guān)系,包含關(guān)聯(lián)關(guān)系。不管是B類對(duì)象是A類對(duì)象的成員變量,還是A類方法使用B類對(duì)象作為參數(shù)或者返回值、局部變量,只要B類對(duì)象和A類對(duì)象有任何使用關(guān)系,我們都稱他們有依賴關(guān)系。

圖例:

使用 虛線箭頭 表示。

代碼實(shí)現(xiàn):

  1. public class A { 
  2.     private B b; 
  3.     public A(B b){ 
  4.         this.b = b; 
  5.     } 

或者

  1. public class A { 
  2.     private B b; 
  3.     public A () { 
  4.         this.b = new B(); 
  5.     } 

或者

  1. public class A { 
  2.  public void func(B b) 
  3.         ... 
  4.     } 

模型簡(jiǎn)化

嚴(yán)格的UML類圖之間的關(guān)系拆分的太細(xì),專業(yè)要求很高,大大增加了學(xué)習(xí)成本,而且對(duì)于業(yè)務(wù)溝通,指導(dǎo)后續(xù)數(shù)據(jù)庫設(shè)計(jì),編程開發(fā)沒有太大意義。

所以在實(shí)際業(yè)務(wù)建模過程中,我們并不需要嚴(yán)格按照UML類圖交互關(guān)系來描述業(yè)務(wù)實(shí)體之間的關(guān)系,比如我們可以將聚合、組合、關(guān)聯(lián)統(tǒng)統(tǒng)使用關(guān)聯(lián)關(guān)系表示,使用實(shí)線連接兩個(gè)實(shí)體,并在兩側(cè)標(biāo)記出實(shí)例個(gè)數(shù)即可。

小結(jié)

領(lǐng)域模型最終呈現(xiàn)后的結(jié)果很簡(jiǎn)單,但是過程卻很復(fù)雜。需要架構(gòu)師基于自身的業(yè)務(wù)知識(shí)和類似產(chǎn)品的參考,再結(jié)合客戶、業(yè)務(wù)專家、領(lǐng)域?qū)<业淖稍兒椭笇?dǎo),需要經(jīng)過不斷推倒、修改優(yōu)化才能完成。

對(duì)于剛開始接觸領(lǐng)域模型的繪制時(shí)經(jīng)常會(huì)出現(xiàn)下面兩種典型錯(cuò)誤:

將待開發(fā)系統(tǒng)也放在領(lǐng)域模型里面 待開發(fā)系統(tǒng)要不要出現(xiàn)在領(lǐng)域模型中取決于你的業(yè)務(wù)離開待開發(fā)的系統(tǒng)能不能玩的轉(zhuǎn)。舉個(gè)例子:如果開發(fā)的是共享單車的信息系統(tǒng),共享單車離開信息系統(tǒng)肯定玩不轉(zhuǎn),所以這時(shí)候信息系統(tǒng)需要出現(xiàn)在領(lǐng)域模型。

概念劃分不清,關(guān)系沒有畫到位 比如屬性畫成了類,繼承關(guān)系搞錯(cuò)

 

責(zé)任編輯:武曉燕 來源: JAVA日知錄
相關(guān)推薦

2022-04-19 08:15:53

DDD領(lǐng)域建模實(shí)戰(zhàn)

2024-07-08 08:45:41

2011-10-19 09:20:44

2011-10-21 09:04:57

系統(tǒng)架構(gòu)師

2011-10-27 09:08:59

系統(tǒng)架構(gòu)師

2019-07-23 18:15:26

技術(shù)大數(shù)據(jù)數(shù)據(jù)庫

2021-10-25 09:41:04

架構(gòu)運(yùn)維技術(shù)

2021-07-12 23:43:46

AppAndroid優(yōu)化

2011-10-20 09:06:36

系統(tǒng)架構(gòu)師

2011-10-24 09:26:42

系統(tǒng)架構(gòu)師

2022-03-11 10:53:32

UML建模語言

2023-07-26 08:00:00

DDD架構(gòu)微服務(wù)

2012-04-05 10:25:02

WEB架構(gòu)師

2012-04-09 09:41:24

WEB架構(gòu)師

2018-07-03 15:46:24

Java架構(gòu)師源碼

2018-02-06 09:58:48

架構(gòu)師MVCiOS

2020-11-25 09:56:48

架構(gòu)運(yùn)維技術(shù)

2022-06-15 10:04:51

存儲(chǔ)選型MySQL

2012-03-31 10:00:05

WEB架構(gòu)師

2009-02-23 11:18:06

J2EE架構(gòu)師Java
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)