写点什么

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:002993

评论

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

面试不再慌!苦学这份2023最全的Java性能优化实战笔记,已涨17k

Java你猿哥

Java 面试 JVM 多线程 Java性能优化

Java8 lambda 表达式 forEach 如何提前终止?

Java你猿哥

Java ssm java8 foreach

程序性能提高了5倍!开源阿里500页的Java程序优化笔记

Java你猿哥

Java 面试 性能优化 Java虚拟机 Java性能优化

SpringBoot核心配置全面总结

小小怪下士

Java 程序员 后端 springboot

分布式事务的21种武器 - 5

俞凡

架构 云原生

面试官:一千万的数据,你是怎么查询的?

Alibaba内网“疯狂”传阅的P8开源出的SpringBoot入门到进阶小册

Java spring 微服务 Spring Boot 框架

五张图带你看透Redis数据结构

GitHub爆赞!阿里P9架构师的JDK源码笔记也太强了!

Java 源码 jdk 高并发

分布式事务的21种武器 - 4

俞凡

架构 云原生

字节速通!这份软件测试八股文还怕不能拿offer?你值得拥有

Java你猿哥

MySQL 面试 软件测试 计算机 八股文

速通字节!阿里p8耗时6个月打造的java面试手册,看到直呼“面试有手就行”

Java你猿哥

Java spring 微服务 JVM 多线程

基于Alpine制作Tomcat的Docker镜像

清康

运行第一个程序Hello world

鸿蒙之旅

OpenHarmony 三周年连更

https和http有什么区别?

海拥(haiyong.site)

三周年连更

Redis数据类型及底层大剖析

Java 数据库 redis 缓存

太强了!牛客网开源1240页字节算法实录,无意中掀起GitHub刷题热潮

Java 数据结构 算法 LeetCode

ZooKeeper 避坑指南: ZooKeeper 3.6.4 版本 BUG 导致的数据不一致问题

阿里巴巴云原生

zookeeper 阿里云 开源 云原生

为什么《魂斗罗》只有128KB却可以实现那么长的剧情?

Java你猿哥

Java 编程 程序员 汇编语言 优化技术

我懵了,如果要存 IP 地址,用什么数据类型比较好?

Java你猿哥

Java MySQL 数据库 ssm IP

Python的常见数据结构

timerring

Python

MATLAB与Simulink

袁袁袁袁满

三周年连更

一文了解获得 Zebec Labs 投资的 Coral Finance,空投计划或在不久推出

西柚子

爆赞!GitHub上久经不衰的经典教程:Springboot精髓参考指南手册

Java spring 微服务 Spring Boot 框架

K8s 安全是云安全的未来

HummerCloud

Kubernetes k8s

三种常用的以太网端口链路类型:Access、Hybrid和Trunk

wljslmz

网络 三周年连更

声网 Token 鉴权机制,以及常见的问题

声网

MySQL深分页问题原理与三种解决方案

Java MySQL 数据库

什么是数据库分片?

Java架构历程

Java 数据库 三周年连更

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