DDD理论学习系列(5)-- 统一建模语言

1.引言

上一节讲解了领域模型,领域模型主要是将业务中涉及到的概念以面向对象的思想进行抽象,抽象出实体对象,确定实体所对应的方法和属性,以及实体之间的关系。然后将这些实体和实体之间的关系以某种形式(比如UML、图形、代码、文字描述等)展现出来。而领域模型是领域建模的结果,那如何建模呢?我们可以借助于UML。

我们知道UML(统一建模语言)是一种用于绘制软件概念图的图形符号。在和他人交流以及帮助解决设计问题方法,图示是最有效的。在DDD中我们习惯用UML进行领域建模,所以为了后续章节的展开,我们需要而且必须熟悉常用UML的使用。之前也写了一篇文章,想要学习设计模式,你得先会看类图,一张图读懂UML,介绍了一些基本的用法,不妨一看。

下面就开始简单介绍下几种常见的UML的基本用法。

2. UML的级别和类别

在《UML精粹》中,UML主要被分为三个级别:

  • 概念级别:用来描述问题领域中概念和抽象的一种速记方法,没有比较严格的语义规则。和源代码之间没有很强的关联性。

  • 规格说明级别:描绘问题的解决方案,目的是为了能够转换成源代码。要遵循严格的语义规则。

  • 实现级别:用来描绘已有的源代码,如类图。要遵循严格的语义规则。

UML主要有三种图示类别:

  • 静态图(static diagram):描述了类、对象、数据结构以及它们之间的关系,展现出软件元素间不变的逻辑结构。类图、对象图都是静态图。

  • 动态图(dynamci diagram):展示软件实体在运行过程中是如何转换的,其中描述了运行流程或实体改变状态的方式。顺序图、协作图、状态图都是状态图。

  • 物理图(physical diagram):展示软件实体不变的物理结构,描述了诸如源文件、库、二进制文件、数据文件等物理实体以及它们之间的关系。

3. 案例分析

为了真正对UML有一个直观的认识,我们还是结合具体的业务场景(购物车)举例分析,进行UML图示 设计。

3.1.类图

类图主要展示程序中主要的类和关系。
购物车主要涉及到四个对象:购物车、购物车子项、商品、类别。

在本图中,所有的关系都是聚合关系。

3.2. 对象图

对象图展示的是系统执行的某个特定时刻的一组对象和关系,可以看作内存快照。

该图示就展示了当前购物车有两件商品。

3.3.顺序图

顺序图是一个动态模型,是为了清楚表达出消息的顺序。

其中要注意几个图示:

  • 虚线:生命线。

  • 窄条小矩形:激活,表示函数执行的时间。

  • 方括号中的布尔表达式:监护条件。

  • 小圆圈箭头:数据标记

3.4.协作图

协作图是为了表达出对象之间的关系。

3.5.状态图

状态图是为了理解系统的行为和状态的转换。

该图就简要描述了,订单从正常、发货、关闭之间的状态转换。

4.总结

本文通过简单的案例简单介绍了几种常用的UML的用法。由于自己对UML也不是很了解,以上图示难免有所纰漏。

UML本身是一个复杂的东西,要完全掌握它是需要耗费很大时间和精力。但是我们在建模时要本着越少越好的思想去使用它。不要过于追求图示的详细程度,且UML图不是源代码,没有必要申明所有方法、变量和关系。
在学习UML的时候,不建议一上来就去找一些UML画图工具,直接在纸上写写画画就好,本文的所有图示就是直接在草稿上设计的。

最后,最最最重要的是,请动手画!

相关文章

  • DDD理论学习系列(1)-- 通用语言

  • DDD领域驱动之干货 (一)

  • DDD理论学习系列(2)-- 领域

  • DDD理论学习系列(3)-- 限界上下文

  • DDD理论学习系列(4)-- 领域模型

  • 事件总线知多少(2)

  • 从事件和DDD入手来构建微服务

  • DDD领域驱动之干货 (一)

  • WeText项目:一个基于.NET实现的DDD、CQRS与微服务架构的演示案例

  • 【DDD/CQRS/微服务架构案例】在Ubuntu 14.04.4 LTS中运行WeText项目的服务端

原文地址:http://www.cnblogs.com/sheng-jie/p/6984213.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/324830.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java中你知道这四种代码块吗?

大家好,我是雄雄,今天给大家分享的是:java中构造代码块的用法。 什么叫代码块?代码块将多行代码封装到一个{}中,形成一个独立的代码区,这就够成了代码块,一般常见的代码块是这样的: …

jzoj2152-终极数【堆】

题目(复杂) 给定一个长度为n的序列a,试求出对于序列a的每一个前缀的终极数x,使得 最小,试求出终极数t(如若有多个终极数t,只需输出最小的那个) 正解 其实就是求中位数… 输入 …

谈谈准确率(P值)、召回率(R值)及F值

转载自 谈谈准确率(P值)、召回率(R值)及F值 谈谈准确率(P值)、召回率(R值)及F值 一直总是听说过这几个词,但是很容易记混,在这里记录一下。希望对大家理解…

线程创建两种方式

方式一(继承于Thread类) 创建一个继承于Thread类的子类重写Thread类的run() --> 将此线程执行的操作声明在run()中创建Thread类的子类的对象通过此对象调用start() package com.wdl.java;//1. 创建一个继承于Thread类的子类 class MyThread extends Thread {//2. 重写Thre…

在ASP.NET CORE 2.0使用SignalR技术

一、前言 上次讲SignalR还是在《在ASP.NET Core下使用SignalR技术》文章中提到,ASP.NET Core 1.x.x 版本发布中并没有包含SignalR技术和开发计划中。时间过得很快,MS已经发布了.NET Core 2.0 Preview 2 预览版,距离正式版已经不远了&#xf…

java中常见的几种内部类,你会几个?(未完)

点击上方蓝色关注我们!大家好,我是雄雄,今天给大家介绍的是java中的几种内部类。java中常见的几个内部类,你会几个?我会四个!在看每个新知识点时,我们不禁有这样或者那样的疑问,比如…

通俗理解信息熵

转载自 通俗理解信息熵 通俗理解信息熵 前段时间德川和我讲解了决策树的相关知识,里面德川说了一下熵,今天整理了一下,记录下来希望对大家理解有帮助~ 1、信息熵的公式 先抛出信息熵公式如下: 其中代表随机事件X为的概率&…

.NET Core 2.0 Preview 2为开发人员带来改进

Microsoft发布了.NET Core 2第二个预览版(Preview 2),该版本可用于Mac OS X、Linux和Windows平台。Preview 2首次给出了对所有平台上各种软件包和安装程序的统一命名模式。所有的运行时文件将以"dotnet-运行时名称”命名,而S…

java中,剩下的这两个内部类不太好理解!

点击上方蓝色关注我们!大家好,我是雄雄,今天我们接着昨天的分享,将剩余的两个内部类(方法内部类和匿名内部类)结束掉,这两个内部类都不太好理解。昨天的推文:java中常见的几种内部类…

【jzoj】2018.2.3NOIP普及组——D组模拟赛

前言 万年D组系列… 正题 题目1:数池塘(jzoj1898) 有一个地方有一些积水,连着的积水是一个池塘,求池塘数。 输入 第1行:由空格隔开的两个整数:N和M 第2..N1行:每行M个字符代表…

通俗理解条件熵

转载自 通俗理解条件熵 通俗理解条件熵 前面我们总结了信息熵的概念通俗理解信息熵,这次我们来理解一下条件熵。 1、信息熵以及引出条件熵 我们首先知道信息熵是考虑该随机变量的所有可能取值,即所有可能发生事件所带来的信息量的期望。公式如下: 我…

WebAssembly:随风潜入夜

What? WebAssembly 是一种二进制格式的类汇编代码,可以被浏览器加载和并进一步编译成可执行的机器码,从而在客户端运行。它还可以作为高级语言的编译目标,理论上任何语言都可以编译为 WebAssembly。 我们知道汇编语言就是机器码的…

让java的多重继承成为现实!

点击上方蓝色关注我们!大家好,我是雄雄,前两天给大家说了说java中的四种内部类,推文分别为:静态内部类和成员内部类方法内部类和匿名内部类在内部类的基础上,我们来看看今天的知识点儿。众所周知&#xff0…

通俗理解决策树算法中信息增益的

转载自 通俗理解决策树算法中信息增益的 通俗理解决策树算法中的信息增益 在决策树算法的学习过程中,信息增益是特征选择的一个重要指标,它定义为一个特征能够为分类系统带来多少信息,带来的信息越多,说明该特征越重要&#x…

DDD理论学习系列(6)-- 实体

1.引言 实体对应的英语单词为Entity。提到实体,你可能立马就想到了代码中定义的实体类。在使用一些ORM框架时,比如Entity Framework,实体作为直接反映数据库表结构的对象,就更尤为重要。特别是当我们使用EF Code First时&#xf…

班级日常 | 一天一瞬间!

点击上方蓝色关注我们!欢迎来到今天的“一天一瞬间”专栏在学习word操作时,同学们的兴趣还是较高的,但是,比起“一天一个黑科技”来说,还是差了许多!前面两天都是学的一些简单的DOS命令,比如进某…

ASP.NET Core Web 资源打包与压缩

本文将介绍使用的打包和压缩的优点,以及如何在ASP.NET Core应用程序中使用这些功能。 概述 在ASP.Net中可以使用打包与压缩这两种技术来提高Web应用程序页面加载的性能。通过减少从服务器请求的次数和减少资源文件的体积来提高加载性能。 打包是一地将多个文件&a…

班级日常分享 | 一天一瞬间!

点击上方蓝色关注我们!介于最近同学们的学习劲头十足的样子,我和丁老师商量决定晚上不布置作业,看一部电影放松放松!昨晚下晚自习后,零零散散的还有一部分同学在教室里面学习,值班老师都催促多次&#xff0…

句法分析(syntactic parsing)在NLP领域的应用是怎样的

转载自 句法分析(syntactic parsing)在NLP领域的应用是怎样的 句法分析(syntactic parsing)在NLP领域的应用是怎样的? 文章整理自郭江师兄问题回答(被收录于知乎编辑推荐)!已取得…