- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在使用域驱动设计构建的应用程序中遇到一些概念上的麻烦。
我有以下几层:
应用
域
基础设施
因此,假设我有以下课程:Order
EmailService
OrderNotificationService
OrderApplicationService
显然,Order
进入域层,而OrderApplicationService
进入应用层。 EmailService
是用于发送电子邮件的常规服务,并在基础结构层中实现。 OrderNotificationService
是用于发送订单通知的特定实现。 OrderNotificationService
使用EmailService
发送实际的电子邮件。
因此,我的第一个问题是:OrderNotificationService
是作为域服务,应用程序服务还是基础结构服务实现的?
对于我的下一个问题,让我们假设以下对象:Employee
SalesforceService
假设当员工被添加到系统中时,他们也应该被添加到Salesforce中。 SalesforceService
是使用Salesforce api注册用户的服务。 SalesforceService
是通过发送员工信息将其实现为应用程序服务将使用的域服务还是通用基础结构服务?
谢谢你的建议。
最佳答案
这听起来不像DDD
关于您的域模型,您的问题中没有太多内容。您提到了“将雇员添加到系统和Salesforce中”,但除此之外,从业务的角度来看,我对您的应用程序打算做什么没有真正的了解。我对“雇员”和“ Salesforce”的理解是基于对词语的熟悉,而不是基于他们在系统中的模型解释。
对于您的模型,“订购应用程序服务”应该代表什么我真的不了解。我得到一个“订单”和“订单通知”。似乎“客户”发出了“订单”,有些“订户”得到了“通知”,但这很多是基于我对设计模式的先前了解。
您应该能够描述业务域模型,因为如果计算机不存在,它将可以正常工作。如果您需要一个计算机术语来解释这个想法,那么它可能是模型中外在的东西。
显然,您需要将应用程序逻辑与域逻辑集成在一起,但这不会引起您的疑虑。但是,有一些解决方法。
如何解决
您可以使用接口而不是特定于实现的类在域层中对服务进行建模。这称为interface segregation principle。有意义的是,模型的一部分包括当客户下订单时通知负责的员工。但是,此通知的实现并不一定要与其建模目的耦合。在拥挤的办公室中,可能有主管通过对讲机发布通知,或者可能有自动化系统发送的电子邮件。这两个示例都具有相同的业务目的。可以将一个IOrderNotificationService
接口简单地包含一个方法void NotifyOrderReceived(Order order);
,而不是在域层中嵌入电子邮件服务。这样,您就可以在域层中拥有所需的所有业务逻辑,而不会引起不必要的担忧,例如“电子邮件”实现或数据库的持久性。我正在猜测,但是您的OrderNotificationService
和OrderApplicationService
实际上是对同一事件的响应,但是一个具有数据库依赖性,另一个具有SMTP依赖性。两者都是基础设施问题。
在许多情况下,针对单个接口进行编码就足够了。但是,存在一个问题,您的域对象现在依赖于注入的服务或全局变量。同样,这可能表明这些实体对它们的依赖性了解得太多。客户可能不需要知道如何处理订单的内部工作原理,而只需要知道已处理订单即可知道所收到的订单。同样,员工可能不会将自己添加到Salesforce中,因为他在成为员工之前并不知道这一点。他所知道的就是他刚刚找到工作。
这个问题有很好的解决方案...
您可以使用“域事件”模式。基本思想是,域对象仅知道刚刚发生的事情以及它们的状态如何更改,而无需了解任何有关持久或传播已更改状态的信息。他们处理内部逻辑,然后引发“域事件”。这更类似于客户下订单然后大声喊“ Yo,我订购了该产品!”。或某个雇员被录用然后大喊:“是的,我找到了工作!”。采用这种方法将大大简化您的域逻辑,并使您可以更清晰地分离关注点。 Udi Dahan撰写了一系列精彩的博客文章,他在其中解释了利用Domain Event模式背后的逻辑,并提供了一个非常简单但非常有效的实现。以下是一些链接:
How to create fully encapsulated Domain Models
Domain Events – Take 2
Domain Events - Salvation
现在,如果您是喜欢在完全理解代码之前复制和粘贴代码的开发人员,那么建议您从这些文章的第三篇开始。他们记录了乌迪·达汉(Udi Dahan)对模式的看法和经验的演变。最合理的代码示例出现在第三篇文章中。理想情况下,您将按顺序阅读所有三个内容,以便您可以遵循他的逻辑并真正理解您如何从他的方法中受益,以及为什么它可以准确地表示“域驱动设计”。
作为“域事件模式”的补充理由,埃里克·埃文斯(Eric Evans)在2009年回顾了自从他撰写开创性著作以来所学到的关于域驱动设计的知识,这表明域事件是他的书中被大大忽略的核心组成部分。 here提供了他的演讲摘要,并且here提供了演示文稿的链接。
其他可能有助于您成功应用此模式的资源包括Jimmy Bogard的文章Strengthening your Domain: Domain Events和Martin Fowler's Domain Event article。 Bogard具有从引用的链接到其他有用的DDD博客文章的链接。
一般来说,
如果您真的想尝试应用领域驱动的设计,那么您将真正了解您要建模的内容以及为实现什么目的而要实现的内容,将会获得更大的成功。仅使用您不熟悉的术语并以这样的方式标记代码没有任何隐含的价值。 DDD可能会非常有用,但是如果您不花时间去理解为什么要进行区分和设计决策,则会导致很多不必要的抽象和普遍的混乱。
关于oop - 域驱动的设计概念,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12322736/
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
在面向对象的编程中,“基类”是派生其他类的类(http://en.wikipedia.org/wiki/Base_class)。 但是,基类的反面是什么?换句话说,什么是没有任何子类的类? 编辑:我正
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 8年前关闭。 Improve this questi
据我了解,OOP 是大型项目最常用的范式。我也知道大系统的一些较小的子集使用其他范式(例如 SQL,它是声明性的),并且我也意识到在较低级别的计算 OOP 并不真正可行。但在我看来,通常更高级别的解决
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
最近听说OOP(Java)有9条规则。我只知道四种:抽象、多态、继承和封装。 OOP 还有更多规则吗? 最佳答案 看来您正在寻找的是 Principles of Object-Oriented Des
我曾经在一次采访中被问到“OOP 的 3 个主要概念是什么?”。我回答说,我认为有4个,如下: 继承 封装 抽象 多态性 我说得对吗? 最佳答案 语言要成为面向对象有3个要求: 仅支持封装(对象)的语
我有一个关于特定 OOP 问题的组织的简单问题。 假设我有一个地形类,里面充满了瓷砖。 Tile 类有多个派生类,即 Door。 Door 类有一个名为 open() 的方法,用于打开门,还有一个名为
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我是 Go 的新手,然后我通过示例搜索了很多如何拥有带有静态函数/变量的静态类,例如 C#。但是,我找不到任何可以很好地回答它的东西。也许这个问题看起来很愚蠢,但我不喜欢不确定或不完全理解某事。 假设
我曾尝试搜索此问题的答案,但很难用语言表达,而且许多问题要么是关于如何创建类,要么是关于如何做非常具体的事情。我需要更多的实用概述 - 我是自学成才的,我了解对象是什么(以及如何创建它们),但我从未见
在开始编码之前,我通常会尝试在没有太多分析(没有图表)的情况下进行 TDD。通常我发现自己将一个类拆分为其他类以分离关注点。我想知道更深入的分析是否会阻止这种情况。我认为大部分面向对象分析无法预测其中
在阅读单例时,我发现这个解释是使用单例的原因: since these object methods are not changing the internal class state, we can
如这里所述 https://standardofnorms.wordpress.com/2012/09/02/4-pillars-of-object-oriented-programming/ 并作为
我是这个网站的新手,所以如果我在发布问题时做错了什么,请告诉我,以便我下次修复。 我很好奇从单个基类继承多个类是否是糟糕的 OOP 实践。这可能不太合理,所以我要详细说明一下。 例如,假设您正在设计一
我对“工厂相关”设计模式及其 OOP 实现的理解一直很简单。 一个 《工厂法》是类内部的一个方法,它有一个接口(interface)(或抽象类)作为返回类型,并根据一些内部逻辑构造实现该接口(inte
C# 中的“密封”关键字,Java 中的 Final。 因为我几乎从不创建任何图表并且我只使用已经完成的类(来自框架)我多年后仍然不知道为什么有人会“锁定”一个类所以它永远不会被扩展/继承。 它是有益
我正在研究面向对象的概念,抽象概念基本上被描述为对用户隐藏实现。因此,如果类中有一个成员函数并且我们为某些任务调用该函数,抽象表示用户不应该关心事情是如何完成的,而应该只知道正在完成什么。但即使在非面
我是一名优秀的程序员,十分优秀!