`
- 浏览:
105580 次
- 性别:
- 来自:
北京
-
领域模型是对领域内的概念类或现实世界中对象的可视化表示。又称概念模型、领域对象模型、分析对象模型。它专注于分析问题领域本身,发掘重要的业务领域概念,并建立业务领域概念之间的关系。
领域模型的概念
什么是领域模型?这个很关键,弄清楚什么是领域模型,才能进行领域模型设计,否则领域模型设计的结果就没有相互讨论的基础。
首先,我想谈谈我的理解。
业务系统一般包括三部分内容:(1)操作者(角色)、(2)系统为操作者提供的行为、(3)操作对象。其中的操作对象就是领域模型的来源。在进行需求分析时,领域模型来自于业务描述中的名词以及对名词的抽象。
当然描述业务的名词不都是模型,有可能是模型的一个属性,也有可能是角色、或者是跟业务无关紧要描述。在业务描述中有些关联名词描述的则是模型之间的关系。例如,在一个业务描述中出现了部门、用户、用户部门、部门用户这些名词,那么领域模型可能只是部门和用户,用户部门则是模型的一个属性,而部门用户表明了部门和用户这两个模型的关系。
一个描述业务的名词成为领域模型,至少具备两点:要么是业务中确实存在的实体、要么是业务实体的提炼(抽象)。
领域模型设计
举一个简单的例子来说明如何进行领域模型设计。
假如我们要为一个小卖店设计一套进销存系统,她为我们提供的业务描述是这样的:每天凌晨从布吉农批市场买苹果、梨、葡萄、橘子、香蕉、荔枝、核桃等等,反正哪些好卖她就买回来卖。葡萄、荔枝不能长久保留,一般要当天卖出去…。
针对上面这段业务描述,我们怎么进行领域模型设计?我给出以下几个步骤来完成领域模型设计。
总结业务描述中的名词
首先建一个名词表,把涉及到的名词列出来:
序号
名词
备注
1.
布吉农批市场
2.
买东西的人
是一个隐含的名词,每天凌晨从农批市场拿货
3.
苹果
4.
梨
5.
葡萄
6.
橘子
7.
香蕉
8.
荔枝
9.
核桃
10.
顾客
是一个隐含的名词,买回来卖的对象
11.
凌晨、当天
时间名词,与实体及角色无关
这个名词列表包括了业务的行为主体:角色,以及业务过程中的操作实体:模型,对我们接下来的用例描述、领域模型分析、需求分析很有帮助。当然这个名词列表需要经过进一步分析提炼,成为领域模型
确定业务实体
序号
名词
描述
1.
布吉农批市场
不是本业务的一个实体
2.
买东西的人
是本业务的一个角色
3.
苹果
是一个实体
4.
梨
是一个实体
5.
葡萄
是一个实体
6.
橘子
是一个实体
7.
香蕉
是一个实体
8.
荔枝
是一个实体
9.
核桃
是一个实体
10.
顾客
是本业务的一个角色
11.
凌晨、当天
时间名词,与实体及角色无关
抽象业务模型
经过分析,我们得出的实体是苹果、梨、葡萄、橘子、香蕉、荔枝、核桃,这些是不是模型呢?应该说还不是,还要经过进一步分析:在我们分析的业务领域内,它们有没有共性?苹果、梨、葡萄、橘子、香蕉、荔枝属于水果,核桃属于干果,它们都是果品的一个具体实例。而在水果中葡萄和荔枝属于不宜保存水果,通过这样进一步的分析得出如下的领域模型图例:
果品进销存领域模型
这个领域模型不但能反映目前的经营实体,同时给我们需求分析人员和系统功能提供了一定的扩展视野:将来会不会经营食品,短期保持水果采取什么利润空间来促销,长期保存的水果会不会因为保存成本而导致利润下降。
领域模型与数据模型的关系
我认为领域模型它是一个分析模型,帮助系统分析人员、用户认识现实业务的工具,描述的是业务中涉及到的实体及其相互之间的关系,它是需求分析的产物,与问题域相关。领域模型是需求分析人员与用户交流的有力工具,是需求分析人员与用户共同理解的概念,是彼此之间交流的语言。而数据模型是系统设计、实现的一部分,描述的是对用户需求在数据结构上的实现,仅此而已。当然数据模型中的概念模型设计与领域模型类似,缺乏的是实体之间更广泛的关系描述。
通常大家会考虑数据怎么存放的问题,我的理解是领域模型设计期间不用考虑数据的存放问题,只考虑业务描述中涉及的实体以及实体之间的关系。
实体之间的关系,很多书都讲了,无非是泛化、依赖和关联,关联又分了一般关联、聚合、组合等等,我这里就不列了。
总结
领域模型设计是需求分析的关键步骤。它帮助用户及需求分析人员建立业务概念,确定用户业务的问题域,系统涉及的业务范围等等。
领域模型设计的步骤为:
1. 从业务描述中提取名词;
2. 从提取出来的名词中总结业务实体,区分名词中的属性、角色、实体、实例,形成问题域中操作实体的集合;
3. 从业务实体集合中抽象业务模型,建立问题域的概念(例如在前面的例子中,我们把容易变质的水果称之为“短期保持水果”,当然也可以是其它说法,只要能跟用户达成共识即可);
4. 用UML提供的方法和图例进行领域模型设计、确定模型之间的关系;
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
"谷歌、斯坦福联合发文:我们为什么一定要用大模型?" 大模型是指具有大量参数的语言模型,这类模型在自然语言处理领域取得了重要的突破。它们无需在下游任务上微调,通过合适的指令或者提示就可以取得优异的性能,...
"领域模型"则是对这个领域的抽象表示,它包含了业务规则、业务实体、值对象、聚合、领域事件等关键元素。领域模型不仅仅是数据结构,更是业务行为的载体,它能够表达领域专家的思维,并在代码中实现这些业务规则。 ...
如何进行领域模型?我们可以通过多种方式来进行领域模型,包括: 1. 需求分析:了解系统如何工作的需求,包括用户如何与系统交互。 2. 工作领域研究:研究系统所属的工作领域,了解其业务流程和规则。 3. 软件设计...
"使用领域模型构建UML类模型" 领域模型是软件开发中的一种重要技术,它能够捕获系统语境中最重要的对象类型,使用户、客户、开发人员和其他项目相关人员能够更好地理解系统。领域模型可以为开发人员提供重要的信息...
什么是领域模型?领域模型是对领域内的概念类或现实世界中对象的可视化表示。又称概念模型、领域对象模型、分析对象模型。那什么是概念类呢?概念类是思想、事物或对象。这样的解释,仍然显得抽象。还是先看图吧!...
LoRA模型,全称为Low-Rank Adaptation of Large...在实际应用中,LoRA不仅能够用于文本生成,还有潜力扩展到其他领域,如图像生成、音频处理等,只要有大型基础模型存在的地方,LoRA都有可能成为优化和定制的有效工具。
领域模型(Domain Model)和贫血模型(Anemic Domain Model)是两种常见的模型设计模式,它们各有特点,适用于不同的场景。本资料包旨在通过实例对比,帮助初学者理解这两种模型的区别和概念,并提供实际的Java代码...
在IT行业中,领域模型(Domain Model)是一种重要的软件设计概念,尤其在企业级应用开发中占据核心地位。领域模型是对业务领域的抽象和简化,它包含了业务规则、业务实体以及它们之间的关系。本项目示例旨在提供一个...
贫血模型or领域模型的举例对比,让你初步了解贫血模型与领域模型的区别和概念
领域模型是软件开发中的一个重要概念,特别是在面向对象设计和领域驱动设计(DDD)中。它是一种将业务领域的概念、规则和行为转化为计算机程序的方式。在本文中,我们将深入探讨领域模型的理论基础,以及如何在实际...
在本示例中,"领域模型代码示例"是一个用于展示DDD实践的演示项目,帮助开发者理解和应用DDD原则。 领域模型是DDD的核心部分,它是对特定业务领域的概念、规则和行为的抽象表示。一个领域模型通常包含实体...
DDD的核心理念是将复杂的业务逻辑转化为清晰的领域模型,以此来提高软件的可维护性和可扩展性。下面将详细阐述DDD领域的模型设计方案及其关键概念。 1. **领域模型**:领域模型是DDD的核心,它代表了业务领域的核心...
### 领域模型管理与AOP:深入理解与实践 #### 一、引言与背景 在现代软件开发过程中,领域驱动设计(Domain-Driven Design, DDD)已经成为构建复杂业务系统的有效方法之一。通过定义清晰的领域模型,开发者能够更...
### UML领域模型介绍 #### 一、领域模型概述 UML(Unified Modeling Language,统一建模语言)是一种广泛应用于软件工程领域的图形化语言,用于描述系统的结构和行为。领域模型是UML中的一个重要概念,它主要关注...
第2章 领域分析模型 核心域,支撑子域,通用子域 微服务和DDD是什么关系? 传统模式下如何合理的划分各种域 基于DDD的方式进行域划分 什么是通用语言 什么是限界上下文? 限界上下文和子域的关系 基于电商系统按流程...
火龙果软件工程技术中心 信息系统整体的领域模型,是对业务中主要对象和对象之间关系的设计和描述,领域模型可以说是一体化数据模型的基础和核心,因为数据库设计和应用程序划分,都依赖于领域模型所表达出来的思想...
在本文档中,作者提出了一个基于领域模型的系统需求获取方法。这种新方法的目的是为了更准确和完整地获取应用系统的需求。该方法的核心在于使用领域工程的思想,识别出应用系统中的共同特征,并将这些特征进行抽象化...
领域模型是对业务领域的抽象,包含了业务实体、值对象、聚合、领域事件、领域服务等元素。领域模型是业务逻辑的载体,它将业务规则和操作封装其中,使得代码更具有可读性和可维护性。 1. **领域实体**:领域实体...
大模型的优势:大模型能够处理复杂的任务和大规模的数据集,在自然语言理解、图像分析和语音识别等领域取得了显著的性能提升。 典型的人工智能大模型包括 OpenAI GPT 系列、Google BERT 模型、Facebook RoBERTa ...