写点什么

当 DDD 遇上 DCI(Data, Context, Interactive)架构模式

  • 2019-08-11
  • 本文字数:938 字

    阅读完需:约 3 分钟

当 DDD 遇上 DCI(Data, Context, Interactive)架构模式

ArchSummit深圳2019大会上,张晓龙讲师做了《当 DDD 遇上 DCI(Data, Context, Interactive)架构模式》主题演讲,主要内容如下。


演讲简介


DCI 是数据、场景、交互(Data、Context、Interactions)简称,重点是关注数据的不同场景的交互行为,是面向对象系统状态和行为的一种范式设计;DCI 在许多方面是许多过去范式的统一,多年来这些模式已经成为面向对象编程的辅助工具。


问题背景:电信软件的功能复杂特性交叉,对实时性和数据一致性的要求比较高,代码规模比较大,同时处理大量并发活动。


解决方案选型:1.领域建模+贫血模型;2.领域建模+充血模型;3.领域建模+DCI。


方案介绍:选择“领域建模+DCI”,将类和对象看成不同的事物。类作为一种模块化手段,遵循高内聚,低耦合,让软件易于应对变化;将类看做是领域对象拥有的职责或扮演的角色,对象作为一种领域对象的的直接映射,解决了过多的类带来的可理解性问题,让领域可以指导设计,设计真正反映领域。如果使用 C++ 语言来实现的话,可以通过多重继承的方式来完成职责 ROLE 的组合 ;如果使用 Go 语言来实现的话,可以通过依赖注入的方式完成职责 ROLE 的组合。


实施后效果说明:DCI 可以和 DDD 融合在一起,基于职责的组合式设计提高了代码的可理解性和应对变化的能力,而且对于开发人员来说 DCI 带来的收益比 DDD 更大。


演讲提纲


  1. DCI 架构模式

  2. Data,Context,Interaction

  3. 优缺点

  4. DCI 是 DDD 的补充

  5. 类与对象的关系

  6. DCI 与 DDD 的融合

  7. ROLE 的建模

  8. 数据依赖管理

  9. 领域模型各部分的可组合性

  10. 实践案例

  11. 案例介绍

  12. 物理设计

  13. 领域模型设计

  14. 代码实现要点

  15. 小结

  16. DCI 与 DDD 的融合

  17. 审视类与对象的关系

  18. DCI 落地的核心是 ROLE 的建模

  19. 对于开发人员来说 DCI 的收益比 DDD 更大


听众受益点


  1. 理解 DCI 架构模式

  2. 明白 DDD 和 DCI 的关系

  3. 清楚团队基于 DDD 落地 DCI 的方法


讲师介绍


张晓龙


中兴通讯 资深软件架构师


Gomonkey 和 Go 语言 trans-dsl 作者,具有十多年软件架构和开发经验,近年专注 PaaS 和 5G 等大型项目的设计和开发,精通微服务契约测试。爱读书,爱运动,爱编程,爱分享,对于大型软件的重构具有丰富的实战经验。曾指导多个团队积极实践 DDD,包括开发领域和测试领域,取得了比较好的效果。












完整演讲 PPT 下载链接


https://archsummit.infoq.cn/2019/shenzhen/schedule


2019-08-11 00:005906

评论

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

JavaScript 概念 - 事件循环

yuanyxh

js #前端

应用闪退分析与 uniapp 安卓原生插件开发

yuanyxh

调试 an'droid #前端

ES6 新特性详解 - let/const

yuanyxh

js ES6 ES5 #前端

ES6 新特性详解 - 迭代器与生成器

yuanyxh

js #前端

ES6 新特性详解 - 类

yuanyxh

js #前端

学习 axios 源码(二)

yuanyxh

js axios #前端

什么是函数式编程

yuanyxh

js 函数式编程 #前端

JavaScript 概念 - 高阶函数

yuanyxh

js #前端

深入浅出 GIF

yuanyxh

js GIF #前端

redux 源码学习

yuanyxh

js Redux #前端

AI耳机成智能硬件布局入口产品 科大讯飞无线智能耳机率先突围

科技热闻

为什么我要牺牲现代浏览器用户的体验去兼容 ie8?

yuanyxh

CSS js #前端

typora & vscode 实现图片自动上传与云

yuanyxh

Typora js #前端

代码风格与编码习惯

yuanyxh

js #前端

ES6 新特性详解 - Promise

yuanyxh

js Promise #前端

ES6 新特性详解 - 箭头函数

yuanyxh

js #前端

ES6 新特性详解 - Symbol

yuanyxh

js #前端

个人博客搭建 - 基于Hexo + Next + Github

yuanyxh

Hexo js #前端

ES6 新特性详解 - 解构赋值

yuanyxh

js #前端

CSS 数据类型与浏览器渐进兼容处理

yuanyxh

CSS #前端

利用 FileSystem API 实现一个 web 端的残缺版文件管理器

yuanyxh

js #前端

Pro Git 阅读理解:Git 是如何实现的

yuanyxh

js #前端

ES6 新特性详解 - 异步函数

yuanyxh

js #前端

HTML5 拖拽 Api 研究

yuanyxh

js #前端

记录一次关于 vuepress 滚动恢复的讨论

yuanyxh

js #前端

JavaScript 概念 - 原型与继承

yuanyxh

js #前端

upload 组件封装

yuanyxh

js 上传 #前端

JavaScript 概念 - 闭包

yuanyxh

js #前端

学习 axios 源码(一)

yuanyxh

js axios #前端

姿态逐渐“亲民” 2024年AI五大趋势备受期待

快乐非自愿限量之名

人工智能

飞猪、去哪儿网接连“出事”,在线旅游平台有多少“坑”?

趣解商业

去哪儿网 飞猪 在线旅游平台

当 DDD 遇上 DCI(Data, Context, Interactive)架构模式_ArchSummit_张晓龙_InfoQ精选文章