- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我读过几篇文章(还有功能域建模
一书),其中建议将域对象的状态与行为分离,但我无法理解这种方法相对于范围域模型的优势.
以下是覆盖域模型的示例:
case class Account(id: AccountId, balance: Money) {
def activate: Account = {
// check if it is already active, eg, enforce invariant
...
}
def freeze: Account = ???
}
我可以通过以下方式使用此帐户进行链式操作:
account.activate.freeze
以下是他们建议的“贫血”方法的示例:
case class Account(id: AccountId, balance: Money)
object AccountService {
def activate = (account: Account) => {
// check if it is already active, eg, enforce invariant
...
}
def freeze = (account: Account) => {
...
}
}
在这里我可以像这样链式操作
activate andThen freeze apply account
除了“优雅”的语法之外,第二种方法的优点是什么?
此外,在到达域模型的情况下,我将在单个类中强制执行不变量,但在“贫乏”模型的情况下,逻辑/不变量可以跨服务传播
最佳答案
我提供两个思维过程,可以帮助解释这个难题:
<小时/>您的示例和书中的状态
概念有所不同。(我确实希望我们都指的是 Functional and Reactive Domain Modeling )。
您的示例状态激活和卡住可能是领域概念,而本书讨论的状态仅用作标记。它们不一定在域逻辑中发挥作用,其存在只是为了消除工作流状态的歧义。前任。 已申请、已批准和已丰富。
<小时/>函数式编程就是实现行为,这些行为独立于传递给它们的数据。
实现此类行为时有两个方面需要注意。
行为可以跨上下文重用。它可以是一个抽象特征,如果你愿意的话,可以是一个幺半群,它采用任何类型T,并在它。在您的示例中,卡住
可能是这样的行为,适用于帐户
、贷款
、余额
等。
该行为没有任何副作用。人们应该能够使用相同的数据集一次又一次地调用该行为,并收到相同的预期响应,而不会影响系统或引发错误。引用您的示例,对帐户重复调用卡住不应引发错误。
结合这两点,可以说将行为实现为跨不同上下文的可重用代码段(作为 Service
),同时确保输入经过验证(即验证处理前作为输入提供的对象的状态)。
通过将对象的可接受状态表示为单独的类型并使用此显式类型参数化模型/对象,我们可以在编译时强制执行输入的静态检查。引用书中提供的例子,你只能批准然后丰富
。任何其他不正确的序列都会引发编译时错误,这比使用防御性防护在运行时检查输入要好得多。
因此,第二种方法最终不仅仅是优雅的语法。它是一种基于对象状态构建编译时检查的机制。
<小时/>因此,虽然输出看起来缺乏模型,但第二种方法是利用函数式编程带来的一些漂亮的模式。
关于scala - DDD功能方式: Why is it better to decouple state from the behavior when applying DDD with functional language?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56836243/
我循环遍历字符串列表以查看该字符串是否包含在字典的值中,然后尝试从该值中删除该字符串。 目前我是这样做的: Dictionary formValues = new Dictionary(); form
我正在将一些旧的 Java 4 代码更新到 Java 8(这里粘贴的太多了),最初的程序员选择让他们的几乎每个类都扩展这个只有静态方法和常量的巨大类,但我不知道他们的推理。 例如: public cl
在使用 z3 解决整数实数约束时,以下两种编写(等效)约束的方法中哪一种更可取(性能方面)? (断言(=>(和( (and (<= (/1.0 1024.0) value) (< value (/1.
我知道这是一个会引起很多争论的话题,但我想知道人们认为使用对象数据源的各种利弊是什么。我现在正在和另一个程序员做一个项目,他的经验和舒适度都 Root 于经典的 ASP,我不确定哪种方式会 a) 快速
抱歉,这是comp-sci 101的问题。我只是不确定是否缺少明显的东西。 因此,假设某些用户输入引发了错误,而我想捕获它并返回一些反馈。错误将是一个数字,0-8。0表示“无错误”。如果错误为3(假设
我们的 JSF Web 应用程序中有多个具有类似功能的搜索页面: 他们有搜索结果(将这些对象称为 T) 有一个包含搜索条件的对象(将此对象称为 C) 他们能够用名称保存搜索条件(将此对象称为 S) 所
我想创建一系列从基础对象继承或复制实例属性的对象。这使我决定使用哪种模式,我想询问您对哪种方法“更好”的看法。 //APPLY: // --------------------------------
我正在构建我的第一个 android 应用程序,也是我的第一个 Java 应用程序。我似乎无法理解枚举和数组列表之间的区别。我正在构建一个简单的闪存卡应用程序,它将包含带有问题的闪存卡,并将其存储为图
我有来自不同来源的客户和潜在客户,我需要弄清楚客户是否已经注册为潜在客户。 我使用 12 个字段进行匹配: address1_clear address2_clear address_clear co
Python 中最好的文字定界符是什么?为什么?单 ' 还是双 "?最重要的是,为什么? 我是 Python 的初学者,我正在努力坚持使用一个。我知道在 PHP 中,例如 "是首选,因为 PHP 不会
这个问题在这里已经有了答案: how to compare two optional NSArrays in Swift (4 个答案) 关闭 6 年前。 我正试图找到一种更好的方法来测试平等性。我
当您有一个表示为数组的循环缓冲区,并且您需要环绕索引(即,当您达到可能的最高索引并递增它时),是否“更好”: return (++i == buffer.length) ? 0: i; 或者 retu
有没有更好的(即更易读的)方式来写这个? if (isset($input_vars['directive']) && $input_vars['directive'] == 'edit') { 最佳
如果我必须在一个句子中找到 let's say a word,我可以想到两种方法 使用 string.IndexOf 使用正则表达式 哪个在性能或最佳实践方面更好 最佳答案 如果不用正则表达式做某事相
我通常知道两种用 C 语言设计通用链表数据结构的方法。我想知道哪种方法更好。在提问之前,我将简要介绍这两种方法: 一种方法是围绕如下结构构建函数: struct list_element {
我总是假设将 double 除以整数会导致更快的代码,因为编译器会选择更好的微码来计算: double a; double b = a/3.0; double c = a/3; // will com
有时,Border控制或 Rectangle控制将满足我的需求。一个例子是,当我正在实现 ControlTemplate 并且我已经在应用分层技术(即在网格中堆叠控件)时,我不需要将不同的 Radiu
代码 (Java) 片段 ..... ..... if ( response.check() == checkNumber ) { String message = "You ar
投资组合A→基金1 投资组合A→基金2 投资组合A→基金3 如果不使用is/has,我就无法框定我的句子。但是在1和2之间 1)具有: class PortfolioA { List obj;
我只是想知道哪个更好,或者更推荐用于处理表单数据。 // Controller // validation etc $data = array('name'=>$this->input->post('
我是一名优秀的程序员,十分优秀!