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

1.引言

在开始之前,我想我们有必要先了解以下DDD的主要参与者。因为毕竟语言是人说的吗,就像我们面向对象编程一样,那通用语言面向的是?
DDD的主要参与者:领域专家+开发人员
领域专家:精通业务的任何人。
开发人员:开发+测试。
领域专家擅长某个领域的知识,专注于交付的业务价值。
开发人员则注重于技术实现。
开发人员总是想着类、接口、方法、设计模式、架构等。以面向对象的编程思想进行思考,思考如何进行抽象、封装、继承、多态等。而领域专家对软件中的框架、持久化、数据库等没有概念,而这也就导致了他们之间交流的困难性。

那怎么解决交流障碍这个问题呢?

2. 通用语言

抛开DDD而言,单从字面意思来理解,我们首先肯定先联想到作为世界使用最多的语言--英语。
英语之所以能成为通用语言,我想无非是以下几方面:

  • 简单易学

  • 使用率高

  • 国际通用

那DDD中通用语言又是怎样呢?
首先它也同样要拥有【简单】的特性,这样才便于理解和传播。
其次,它也要有【通用】、【使用率高】的特性,因为只有在软件开发的过程中,团队范围内所有的参与人员广泛使用,才能准确传递业务规则。

通用语言是团队交流的基础上建立起来的,代码则是基于通用语言来进行业务表达的。

3. 举个例子

项目经理安排了一项任务给我:
圣杰这个补丁处理下【可销控制】这个需求。
听后,真是一脸懵逼,【可销控制】是什么鬼?

这明显是专业术语,我不懂的专业术语。
按照DDD对通用语言的定义,【可销控制】就不算通用语言。
因为只有领域专家知道它的含义,开发人员一脸茫然。

但通用语言是领域专家和开发人员一起创建的,所以我们开个需求会议,来梳理下专业术语背后的含义。

可销控制的应用场景是:
在ERP中,在做单时对销售员负责的客户进行范围控制。比如,A客户是销售员小李发展过来的,小李希望仅能自己负责对A客户的业务。

这么一解释,是不是明白不少了。但是不是还有几点疑惑?

  • 可销范围如何配置?

  • 做什么单据时进行可销范围控制?

  • 如何进行可销控制?

  • 可销控制需不需要参数控制?

经过讨论,得出以下结论:

  • 提供专门的【销售员-客户可销控制】界面进行销售员-客户映射数据配置。

  • 做销售订单单据时进行可销范围控制

  • 在录入销售员后,做单员在选择客户列表时,客户列表中仅显示可销范围配置的客户数据。

  • 提供【销售员-客户可销范围控制】系统参数,勾选后才进行可销范围控制。

好了,这下需求理解个七八九了。
原来可销控制就是销售员-客户销售范围控制。
咱们用一句话来精简下这个需求:
可销控制是指销售员所负责客户的范围控制,当勾选了【销售员-客户可销控制】参数后,在做销售订单录入客户数据时,客户列表仅能选择到在【可销控制】列表中为该销售员配置的客户。

经过这么一说明,我们是不是已经理清了【可销控制】这个需求点。

那这种通过团队交流达成共识的能够简单清晰准确传递业务规则的语言(可以是文字、图片等)即可称为通用语言。

4. 通用语言的价值

就像上面所说的那样,通用语言的最大价值是解决了交流障碍问题,使领域专家和开发人员能够协同合作,从而能够确保业务需求的正确表达。
另外,基于通用语言,开发人员能够开发出可读性更好的代码,从而将业务需求准确转化为代码设计。达到DDD的目标代码即设计,设计即代码。通俗的讲,也就是开发人员写的代码领域专家也能看懂。

5.通用语言的代码表达

既然开发人员也要基于通用语言进行代码开发,那代码如何体现通用语言呢?
在《实现领域驱动设计》书中有一个简单的例子(P238),我们一起来看一下:

  • 系统必须对User进行认证,并且只有当Tenant(租户)处于激活状态时才能对User进行认证。

上面这个用例就是基于通用语言的用例,简单清楚的说明了业务规则。
我们先看第一种代码实现:

bool anthentic = false;
User user = _userRepository().FindUserByTenantIdAndUserName(tenantId, userName);

if(user!=null) {authentic = user.IsAuthentic(password); }
return authentic;

这段代码完全不能反应通用语言,主要存在以下问题:

  1. 这段代码先查找user,再对user进行密码匹配来完成认证。其中user.IsAuthentic(password);表示的是“用户是否被认证”的意思,而没有表达出“认证”这个过程,即“对用户进行认证”。

  2. 未体现“检查Tenant是否处于激活状态”这个前提条件。

知道问题后,我们可以讲代码略做改动:

bool anthentic = false;
Tenant tenant = _tenantRepository.FindTenantById(tenantId);//检查租户是否激活if(tenant!=null&&tenant.IsActive){
User user = _userRepository.FindUserByTenantIdAndUserName(tenantId, userName);
if(user!=null) {authentic = tenant.Authenticate(user, password);//租户对用户进行认证} }
}
return authentic;

以上代码虽然也不是最终结果,但至少对通用语言进行了体现。通读代码,就能明白业务用例,体现代码即设计这一思想。

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


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

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

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

相关文章

定了!对于本周四(7.16日)抽奖活动取消简要说明,新抽奖活动暂定下周三(7.22日)...

大家好,我是雄雄,对于本周四(7.16日)抽奖活动取消简要说明,新抽奖活动暂定下周三(7.22日),欢迎各位粉丝积极参与,奖品已经准备好了,你!准备好了吗…

RabbitMQ系列教程之二:工作队列(Work Queues)

今天开始RabbitMQ教程的第二讲,废话不多说,直接进入话题。 (使用.NET 客户端 进行事例演示) 在第一个教程中,我们编写了一个从命名队列中发送和接收消息的程序。在本教程中,我们将创建一个工作队列,这个队列将用于在…

面试中经常会问的智力题,来看看你会做几道

转载自 面试中经常会问的智力题,来看看你会做几道 下面是大部分题目来自滴滴出行2017秋招题。开始头脑风暴吧~~~ 问题 question one 有50家人家,每家一条狗。有一天警察通知,50条狗当中有病狗,行为和正常狗不一样。每人只能通…

你喜欢什么样的课堂?

最近看了一本书《让课堂充满幽默》,里面有些内容还是觉得挺有道理的。书中开头就说:“大量的课件、复杂的网络,使得老师似乎成了信息管理员和媒体播放机,学生则成为了被灌输的对象”,看后,内心深处反问自己…

main()方法

main()方法的使用说明: main()方法作为程序的入口main()方法也是一个普通的静态方法main()方法可以作为我们与控制台交互的方式。(之前:使用Scanner)

实现自己的.NET Core配置Provider之EF

《10分钟就能学会.NET Core配置》里详细介绍了.NET Core配置的用法,另外我还开源了自定义的配置Provider:EF配置Provider和Yaml配置Provider。本文先来聊聊EF配置Provider的实现,其中会涉及到EntityFramework Core的知识,不熟悉也…

今天的雪糕格外好吃!

赤日炎炎,室外的温度超过30℃。午休罢,教室里一片寂静,大家都有一个目的——等待老师的进来,继续上课。偶尔有几位同学貌似等待焦急,遂将目光瞥向窗外,若有所思。还有几位好动同学在自己的座位上左右摇动&a…

洛谷P2296-寻找道路【日常图论,最短路,SPFA】

题目 一个有向图,要求满足要求的最短路径,要求为: 路径上的所有点的出边所指向的点都直接或间接与终点连通。 输入1 3 2 (3个点,2条边) 1 2 (1和2之间可以连接) 2 1 1 3 (从1到3) 输出1 -1 输入2 6 6 1 2 1 3 2 6 2 5 4 5 3…

活动 | Unity带你亲临王者荣耀KPL总决赛,领略电竞的魅力

《王者荣耀》是由腾讯出品的 Made with Unity的现象级游戏。在Unite Shanghai 2017中的案例专场,我们也曾邀请了《王者荣耀》项目组的技术总监邓君,分享过《王者技术修炼之路》。 从移动游戏到电子竞技,KPL(King Pro League)也是《王者荣耀》…

Java的并发编程中的多线程问题到底是怎么回事儿?

转载自 Java的并发编程中的多线程问题到底是怎么回事儿? 在我之前的一篇《再有人问你Java内存模型是什么,就把这篇文章发给他。》文章中,介绍了Java内存模型,通过这篇文章,大家应该都知道了Java内存模型的概念以及作…

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

1. 引言 领域一词,主要有以下两个意思: 一国主权所达之地。学术思想或社会活动的范围。 不管是指国家的主权范围也好还是学术活动范围,都是在讲一个范围,一个界限。比如我们常说的,学术领域、思想领域、技术领域、语…

最全、最详细的配置jdk十步法!

求关注求转发大家好,我是雄雄。今天给大家分享的是 如何配置jdk ,还记得我当年刚开始自学编程时,jdk配置了好几天才配置好,说来也是惭愧啊。并且配置成功的步骤我自己都不知道是啥,因为当时是东找一个方法,…

RabbitMQ系列教程之三:发布\/订阅(Publish\/Subscribe)

在前一个教程中,我们创建了一个工作队列。工作队列背后的假设是每个任务会被交付给一个【工人】。在这一部分我们将做一些完全不同的事情--我们将向多个【消费者】传递信息。这种模式被称为“发布/订阅”。 为了说明这种模式,我们将构建一个简单的日志…

路径使用场景

路径的使用场景 路径适用的范围:jsp页面中link script img a form 等 如果访问的是其他服务器中的项目文件只可以使用绝对路径 如果访问的是同一个服务器中的其他项目推荐使用根路径 如果访问的是同一个服务器中的同一个项目中的文件推荐使用相对base标签的路径 修改…

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

_ 前言 写博客时间 2018/1/30 22:36。 感想:出数据的dalao我服! 正题 题目1:二项式展开式(jzoj2254) 输入一个整数,求展开(ab)^n。展开方式为 (ab)^n?a^n?a^(n-1)b?a^(n-2)b^2…?b^n 其中” ? “…

开发人员也要懂点的测试知识

转载自 开发人员也要懂点的测试知识 本文来自于作者投稿,作者陈彩华,贝聊后端开发工程师。 最近参加了保利威测试总监李乐的《互联网测试姿势》为主题的分享交流会,收获颇丰,作为一个开放,秉承“不懂产品和测试的开…

转发和重定向

需求说明 用户输入并提交登录信息 登录成功,跳转到success.jsp页面 登录失败,跳转回login.jsp页面 理解图 区别详解

实现自己的.NET Core配置Provider之Yaml

YAML是一种更适合人阅读的文件格式,很多大型的项目像Ruby on Rails都选择YAML作为配置文件的格式。如果项目的配置很少,用JSON或YAML没有多大差别。看看rails项目中的配置文件,如果用JSON写试试什么感受吧。 在《实现自己的.NET Core配置Pro…

信息时代与人工智能时代的教育变革

求关注求转发本文是雄雄的小课堂投稿的第 1 篇文章,作者:小溪时代发展迅速,学校的教育体系却没有很大的改变。比如现在的学生们还是学着几百年前的东西。试想一下,这是否真的适合我们这个时代,亦或真的需要改变了。教育…

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

前言 今天题目比较水and我进了C组,不过太太太太太太太太太太太太太太太太绝望了QAQ。所以我也没有做C组的题。写完博客我就做O(∩_∩)O。 正题 题1:奇数统计(jzoj1547) 就是输入n个数,输出出现次数为奇数的一个数&a…