写点什么

Eric Evans:领域驱动设计的实践

  • 2018-02-25
  • 本文字数:1263 字

    阅读完需:约 4 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

Eric Evans 在最近于阿姆斯特丹举行的 DDD Europe 2018 上做了主题演讲,他认为构建软件时,很重要的一点就是不断探索和练习。他非常青睐领域驱动设计(Domain-Driven Design,DDD)中策略模式,但是他发现真正有意思的是接受一个困难的领域,按照不同的方式进行推导分析,打破窠臼,尝试寻找新的理念,他还以“时间(time)”作为领域举了一些实际的例子。

Evans 是最早的 DDD 图书的作者,经历过很多的项目,在这个过程中,团队发现了领域中很多新的理念,并且能够基于发现的理念构建伟大的软件。但令人遗憾的是,很多项目他无法公开讨论,这些项目相关的业务可能具有保密协议(non-disclosure agreement,NDA),或者它们的领域本身就非常晦涩难懂,需要非常多的时间才能描述清楚。

通用子域(generic subdomain)指的是在很多的系统中都会看到的领域,Evans 发现这些领域很适合作为实践的起点,有些领域我们已经习惯了它们的运行方式,所以被我们长期忽略,它们尤为适合作为起点。他鼓励开发人员在这些领域花费时间去发现和探索新的想法,寻找为它们建模的新的可能性和新的方式。他认为,这是一个战术层面的练习,我们正在设计非常具体的东西,应该通过编码来尝试这些想法。他还指出,有一些真正的变化是非常重要的。在改善模型时,微小的增强非常重要,但是如果我们想要推倒重来的话,就必须要想好可行方案。

Evans 以 Joda-Time 为例进行了说明,这是一个用于时间领域的库,长期以来一直是 Java 程序员的标准工具,并且在进行了一些改善后,纳入了 Java 8。它十年来没有明显的变化,其中一个主要的原因就是对于大多数场景来说,它已经足够好了。因此,我们停止了寻找替代方案,我们非常习惯于使用它,忘记了可能还有替代的方案,甚至已经无法想到完成该功能的其他方式。这种状态被 Evans 称为“遗留性的盲目(legacy blindness)”。按照他的经验,几乎在每个项目中,在以不同的方式进行思考时,很大的一个障碍就是对当前领域的熟悉程度,如果遗留模型非常好的话,那这一点就更明显。打破这种盲目性的一种方式就是找一个具体的场景,展现遗留模型一些不合时宜的地方,并以此作为起点。

Evans 展现了 Joda-time 的几个例子,他据此在时间这个领域寻找新的视角和概念。其中一个样例就是为某个时间实例增加一个月,根据起始时间的不同,结果看起来会有一点诡异:

  • 为 2018 年 1 月 31 日增加一个月,将会返回 2018 年 2 月 28 日;
  • 为 2018 年 1 月 31 日增加两个月,将会返回 2018 年 3 月 31 日;
  • 为 2018 年 1 月 31 日增加一个月,然后对得到的结果再增加一个月,将会返回 2018 年 3 月 28 日。

另外一个具体的例子就是按照新的方式来计算美国感恩节假期的日期,也就是十一月份第四个星期四。他强调练习的目的并不是取代整个库,而是要摆脱对遗留系统的盲目性,在以更好的方式解决问题时,寻找新的理念和想法。

DDD Europe 2019 的计划已经启动,但是具体的日期尚未确定。

查看英文原文 Eric Evans: Practicing Domain-Driven Design

2018-02-25 18:002765

评论

发布
暂无评论
发现更多内容

react hook 源码完全解读

flyzz177

React

React源码解读之任务调度

flyzz177

React

万字详解JVM,让你一文吃透

华为云开发者联盟

开发 华为云 企业号十月 PK 榜

软件测试面试真题 |你用过哪些用例设计方法?

测试人

软件测试 面试题 测试用例

AI 模型编译器 MegCC 开源,解决推理引擎体积问题

MegEngineBot

深度学习 开源 MegEngine MegCC AI 模型编译器

梁胜博士:软件供应链安全两手抓,既要安全左移也要全链路防护丨活动回顾

SEAL安全

DevOps DevSecOps 软件供应链 安全左移 软件供应链安全

一文总结JavaScript手写面试题

helloworld1024fd

JavaScript

那些年面挂的js手写题

helloworld1024fd

JavaScript

认证升级 | 秒云再次获评软件企业认证

MIAOYUN

双软认证 软件企业认证 软件产品认证

专业移动办公解决方案!远程控制软件RayLink内测火热进行中!

RayLink远程工具

远程控制软件 远程办公软件 远控软件 远程桌面连接 RayLink

vue这些原理你都知道吗?(面试版)

bb_xiaxia1998

Vue

业界首个!快手提出亿级别多模态短视频百科体系——快知Kuaipedia

Geek老T

短视频 快手 泛知识

HDC 2022精彩继续,多重亮点进来看!

HarmonyOS开发者

HarmonyOS

谈谈vue面试那些题

bb_xiaxia1998

Vue

如何准备好一场vue面试

bb_xiaxia1998

Vue

谈谈企业级前端应用中客户端渲染和服务器端渲染的区别

汪子熙

前端开发 SSR SAP Spartacus 11月月更

EMQ荣获“2022中国移动创客马拉松OneOS物联网专题赛”三等奖

EMQ映云科技

物联网 IoT emqx 云边协同 车路协同

什么是 HTML 语义化,有什么好处

肥晨

11月月更 HTML语义化 语义化标签

React源码解读之更新的创建

flyzz177

React

从零手写react-router

helloworld1024fd

JavaScript

从零开始实现一个Promise

helloworld1024fd

JavaScript

DevUI开源经验分享:从0到1开始运营你的开源项目

华为云开发者联盟

开源 华为云 企业号十月 PK 榜

vue2项目搭建-使用VUE CLI3.0搭建项目vue2+scss+element简易版

肥晨

脚手架 11月月更 vue2项目搭建

云原生系列四:Yelp 如何在 Kubernetes 上运行 Kafka

叶秋学长

kafka Kubernetes 11月月更 Yelp

我把分布式音乐播放器适配了Stage模型

OpenHarmony开发者

OpenHarmony

docker-compose下的java应用启动顺序两部曲之一:问题分析

程序员欣宸

Java Docker Docker-compose 11月月更

2022年中国汽车OTA行业发展洞察

易观分析

汽车 OTA

vue面试之Composition-API响应式包装对象原理

bb_xiaxia1998

Vue

【GitHub60K+Star】12W字Java后端技术总结,助力2023年春招

程序知音

程序员 java面试 面试技巧 后端技术 Java面试八股文

安防小间距LED显示屏的解决方案是什么

Dylan

LED显示屏 户外LED显示屏 led显示屏厂家

代码质量与安全 | 想在发布竞赛中胜出?Sonar来帮你

龙智—DevSecOps解决方案

代码质量 代码安全

Eric Evans:领域驱动设计的实践_语言 & 开发_Jan Stenberg_InfoQ精选文章