绝了,长文图解DDD建模六个问题与六个步骤,2024年Java技术下半场在哪

本文介绍了如何运用领域驱动设计(DDD)方法论构建一个足球运动员信息管理系统,涉及抽象与灵活的数据模型、四色建模(时标对象、参与方、地、物、角色和描述)、领域事件驱动的业务处理以及API、Controller、Service和Domain层的项目搭建。
摘要由CSDN通过智能技术生成

private Double passSuccess;

private Integer scoreNum;

}

1.6 抽象与灵活

抽象的核心是找相同,对不同事物提取公因式。实现的核心是找不同,扩展各自的属性和特点。例如模板方法设计模式正是用抽象构建框架,用实现扩展细节。

我们再回到数据模型的讨论,可以发现脚本化是一种拓展灵活性的方式,脚本化不仅指使用groovy、QLExpress脚本增强系统灵活性,还包括松散可扩展的数据结构。数据模型抽象出了姓名、身高、体重这些基本属性,对于频繁变化的比赛表现属性,这些属性值可能经常变化,甚至属性本身也是经常变化,例如可能会加上射门次数,突破次数等,所以采用松散的JSON数据结构进行存储。

2、六个步骤

======

工程理论总是要落地的,落地也是需要一些步骤和方法的。本文我们一起分析一个足球运动员信息管理系统,目标是管理运动员从转会到上场比赛整条链路信息,这个系统大家应该也都没有接触过,我们一起来分析。需要说明本实例着重演示DDD方法论如何落地,业务细节可能并不能面面俱到。

2.1 流程梳理

梳理流程有两个问题需要考虑,第一个问题是从什么视角去梳理?因为不同的人看到的流程是不一样的。答案是取决于系统需要解决的是什么问题,因为我们要管理运动员从转会到上场比赛整条链路信息,所以从运动员视角出发是一个合适的选择。

第二个问题是对业务不熟悉怎么办?因为我们不是体育和运动专家,并不清楚整条链路的业务细节。答案是梳理流程时一定要有业务专家在场,因为没有真实业务细节,无法领域驱动设计。同理在互联网梳理复杂业务流程时,一定要有对相关业务熟悉的产品经理或者运营一起参与。

假设足球业务专家梳理出了业务流程,运动员提出转会,协商一致后到新俱乐部体检,体检通过就进行签约。进入新俱乐部后进行训练,训练指标达标后上场比赛,赛后参加新闻发布会。

绝了,长文图解DDD建模六个问题与六个步骤

2.2 四色建模

(1) 时标对象

四色建模第一种颜色是红色,表示时标对象。时标对象是四色建模最重要的对象,可以理解为核心业务单据。在业务进行过程中一定要对关键业务留下单据,通过这些单据可以追溯出整个业务流程。

时标对象具有两个特点:第一是事实不可变性,记录了过去某个时间点或时间段内发生的事实。第二是责任可追溯性,记录了管理者关注的信息。现在我们分析本系统时标对象有哪些,需要留下哪些核心业务单据。

转会对应转会单据,体检对应体检单据,签合同对应合同单据,训练对应训练指标单据,比赛对应比赛指标单据,新闻发布会对应采访单据。根据分析绘制如下时标对象:

绝了,长文图解DDD建模六个问题与六个步骤

(2) 参与方、地、物

这三类对象在四色建模中用绿色表示,我们以电商场景为例进行说明。用户支付购买商家的商品时,用户和商家是参与方。物流系统发货时配送单据需要有配送地址对象,地址对象就是地。订单需要商品对象,物流配送需要有货品,商品和货品就是物。

我们分析本例得到「参与方」包含总经理、队医、教练、球迷、记者,「地」包括训练地址、比赛地址、采访地址,「物」包含签名球衣和签名足球。

绝了,长文图解DDD建模六个问题与六个步骤

(3) 角色对象

在四色建模中用黄色表示,这类对象表示参与方、地、物是以什么角色参与到业务流程。

绝了,长文图解DDD建模六个问题与六个步骤

(4) 描述对象

增加对象相关描述信息,在四色建模法用蓝色表示。

绝了,长文图解DDD建模六个问题与六个步骤

2.3 划分领域

在四色建模过程中我们体会到时标对象是最重要的对象,因为其承载了业务系统核心单据。在划分领域时我们同样离不开时标对象,核心是通过收敛相关时标对象划分业务领域。

绝了,长文图解DDD建模六个问题与六个步骤

2.4 领域事件

当业务系统发生一件事情时,如果本领域或其它领域有后续动作跟进,那么我们把这件事情称为领域事件,这个事件需要被感知。

例如球员比赛受伤了,这是比赛子域事件,但是医疗和训练子域是需要感知的,那么比赛子域就发出一个事件,医疗和训练子域会订阅。

例如球员比赛取得进球,这也是比赛子域事件,但是训练和合同子域也会关注这个事件,那么比赛子域也会发出一个事件,训练和合同子域会订阅。

通过事件交互有一个问题需要注意,通过事件订阅实现业务只能采用最终一致性,需要放弃强一致性,这一点可能会引入新的复杂度需要权衡。

绝了,长文图解DDD建模六个问题与六个步骤

2.5 项目搭建

(1) API

接口层:提供面向外部接口声明和DTO对象

(2) controller

访问层:提供HTTP访问入口

(3) service

业务层:领域层和业务层都包含业务,但是用途不同。业务层可以组合不同领域业务,并且可以增加流控、监控、日志、权限控制切面,相较于领域层更为丰富,提供BO对象

(4) domain

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

最后

给大家送一个小福利

附高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。

…(img-lIfMlwsR-1711875644237)]

最后

给大家送一个小福利

[外链图片转存中…(img-sZ5M1Z80-1711875644237)]

附高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。

[外链图片转存中…(img-5RBZnKx6-1711875644237)]

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
做一个后台管理系统的页面设计需要考虑多个方面,包括用户体验、信息架构、可用性、可维护性等等。下面详细介绍一下如何设计一个高质量的后台管理系统页面。 1. 用户体验 在设计后台管理系统页面时,用户体验是非常重要的。这意味着页面需要易于使用,用户能够轻松找到他们需要的信息。以下是一些设计后台管理系统页面的建议: - 简洁明了的布局:页面应该有清晰的结构和组织,避免过于繁杂的页面布局。在设计页面时,应该尽量简化和组织页面元素,使用户更容易找到所需的信息。 - 直观的导航:设计一个清晰、直观的导航系统,可以帮助用户快速找到他们需要的功能和信息。导航菜单应该被放置在页面的顶部或侧边栏,并使用易于理解的标签和图标。 - 交互式元素:添加交互式元素,如下拉菜单、标签、按钮等,可以提高用户体验。这些元素可以让用户快速完成操作,并让页面更具吸引力。 - 明确的反馈:设计页面时,应该考虑用户在执行操作时需要明确的反馈。例如,在表单提交后显示成功或失败的消息。这可以帮助用户了解他们的操作是否成功。 2. 信息架构 一个良好的信息架构可以帮助用户快速找到他们需要的信息,并且可以让页面看起来更加整洁和有条理。以下是一些设计后台管理系统页面的建议: - 分类信息:对信息进行分类和分组,以帮助用户快速找到他们需要的信息。例如,可以将用户管理、内容管理等相关的功能组合在一起。 - 标签化:在页面上使用标签来帮助用户快速了解信息。例如,在列表中,可以使用标签来标识不同的项目状态。 - 搜索功能:添加搜索功能,可以帮助用户快速找到他们需要的信息。搜索框应该被放置在页面的顶部或侧边栏,并使用易于理解的搜索关键字和提示信息。 3. 可用性 可用性是指页面应该易于使用和理解。以下是一些设计后台管理系统页面的建议: - 明确的标签和标题:页面上的标签和标题应该易于理解和记忆。这可以帮助用户更快地找到他们需要的信息。 - 明确的指示:对用户进行明确的指示可以让他们更容易完成操作。例如,在表单中使用明确的标签和提示信息可以让用户更

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值