`

领域驱动设计之入门级教程(上)

阅读更多

  不知道本篇能否算作是入门级教程,因为大概构思了一下,里面有的是属于教程的东西,有的是相关的知识延伸,有的则什么都不是,就算是一点初级的认识吧,因为我也是接触不久。主要刚看完《领域驱动设计》,是一本不错的书。我看的是免费的pdf精简版,好像卖的话要$30,大家可以买来看看,应该是不错的。购买地址:http://www.lulu.com/product/paperback/domain-driven-design-quickly/2117794

  文中提到软件设计有很多方法,其中一种较为出名的“瀑布设计”。过程就是业务专家提出需求,软件分析人员根据需求建立模型,然后开发人员根据模型进行编码,至上而下的瀑布模式。这个模式应该用了很多年,也应该有很多成功的案例。但是他应用的范围和年代都离我们远去,我想它应该是比较符合需求变化不大,或者是需求较为明朗。它的缺点也很明显,就是信息的流向是单向的,从业务专家-》软件分析人员-》开发人员,不存在信息的反馈(也可能是刚开始的时候,不需要反馈信息)。没有信息反馈的话,后面的一个环节就会根据自己的理解和认识加入自己的东西,就会离业务专家想要的东西越来越远,出来结果之后,就可能是返工开始的日子了。

  另一个文中提到的就是:XP(ExtremeProgramming 极限编程)。书中应该是不太推崇xp,估计是和自己是讲DDD(Domain Driven Development领域驱动开发)有关系吧。敏捷出现的背景应该需求出现了问题,也就是需求的变化,而且是变更频繁,模型就会变更频繁,相应的文档也会变更频繁,开发的代码也就变更频繁。这时候,需要一种新的设计方法来支撑这种局面,改变一下大家的工作方式,于是乎“敏捷”诞生了。它推崇少些文档,不要过度设计,甚至是不要设计,以先满足目前的需求为准,进行代码开发,尽早的让客户看到可以运行的最终版本。等到需求变化了之后,再来进行重构,每一次只要满足当前需求就可以了,进行不断的迭代,越来越趋近于客户的想象。

  虽然它解决了部分的问题,例如:文档没有更新造成的误解、过度设计带来的开发进度失控、复杂性的增加、多做了无用功,但是它也有很明显的缺点,就是它提倡的“简单”,对于简单大家都有自己的理解,同时缺乏了真是可见的模型之后,没有设计,由开发人员进行重构的代码会越来越难以阅读和更改。同时这也是我锁担心的,同时我个人对于敏捷也是保留的。

 

  信息传递失真。

  信息传递失真是说,信息在传递的过程中会迷失本来的意思,传递的环节越多,失真的度会越深,到最后可能就会变成另外一个样子。在http://www.zhiyonw.net/jjx1.htm中介绍了一下《信息失真成本》。

  信息失真存在于各行各业,在我们的软件行业也不例外。书中就例举了例子,软件分析人员和业务领域专家在一起工作了几个月,一起创建了一个正确的模型,模型也代表了正确的领域知识。然后将模型交给开发人员之后,开发人员在看到模型之后,可能会发现在模型中的有些概念不能被正确的转换成代码,然后他们就会以模型为基础,加入自己的设计,虽然也可以实现模型,但是加入了很多自己的东西。随着开发的继续,更多的类被加入系统,原始模型和最终实现的差距就会越来越大。到最后,很难保证系统的质量,就算实现了,可是后面的维护呢?它能经得起实际环境的考验吗?后面还能扩展吗?都可能会出现问题的。

  当然了,书中举这个例子,不光是为了说明信息失真的,好像就没有这个意思,是我自己想到的。它的本意是说一个模型虽然正确,但不代表它容易转换成代码,或者它的实现违反了不推荐的设计模式。这样的模型还是需要迭代的。我们应该选择一个更加容易和轻易转化成代码的模型。

 

  产生上面问题的源泉就因为经过业务专家和软件分析人员建立的模型,对于开发人员来讲还是不适用的,有可能会违反软件设计原则,或者没有办法很好的实现,以为建立模型的时候没有考虑到开发这个因素。

  书中给出的办法就是让开发人员参与到模型设计的过程中,减少模型在开发人员角度的失真,确保在设计模型的时候就考虑到后面的开发。

  可是我觉得这也会产生问题。就是开发人员和业务人员的思考角度是不一样的,甚至可以说是反着的,过早的参与模型,这时候模型还处于业务分析的阶段,开发人员参与业务我觉得不太好。这个工作还是应该由架构师团队来完成,架构师也是开发经验丰富的人员,可以从开发角度来衡量模型的可性能,模型能否容易的转换成代码。可是减少后面开发的复杂性和不确定性。

  所以说这个模型的建立除了业务专家、软件分析人员,还有一个重要的角色就是:架构师。架构师是联系业务和开发的角色。既可以尽早的参与模型的建立,发现业务流程的开发问题,为以后的开发扫清一些不必要的障碍。同时也可以思考后面的软件架构和硬件架构(部署等问题),后续工作的分配。

  

  

  关于如何进行领域驱动设计,会在下一篇的:领域驱动设计之入门级教程(下)中进行详细的介绍。

  本篇就到这里吧,说了一些个人的认识,欢迎大家一起拍砖,提出自己的见解。

分享到:
评论

相关推荐

    pb入门级教程

    【PB入门级教程】深入解析 PowerBuilder,简称PB,是由PowerSoft公司(现已被Sybase收购)开发的一款强大的数据库应用程序开发工具。它基于客户端/服务器(C/S)架构,专为快速构建数据库应用而设计。在C/S体系中,...

    ARM嵌入式入门级教程

    总的来说,“ARM嵌入式入门级教程”是一个全面的起点,它将引导你进入这个充满挑战和机遇的领域。通过这个教程,你不仅会掌握ARM处理器的基础,还能获得开发和调试嵌入式系统的实践经验,从而为未来的项目打下坚实的...

    ARM嵌入式入门级教程.zip

    通过《ARM嵌入式入门级教程.pdf》的学习,你可以逐步掌握ARM架构的原理、嵌入式系统的组成、开发工具的使用以及相关的编程技术,为后续的嵌入式开发打下坚实的基础。在实践中不断学习和探索,你将能够驾驭这个充满...

    ARM教程全集(入门级)

    ARM架构是目前广泛应用在嵌入式系统、移动设备和服务器领域的处理器架构,以其低功耗、高性能的特点受到广泛赞誉。本教程全集是为初学者设计的,旨在帮助你掌握ARM的基本指令集和开发知识。 一、ARM指令集 ARM指令...

    ASP C#入门级资料

    ASP C# 入门级资料是一套专门为初学者设计的学习资源,旨在帮助新手快速掌握ASP.NET平台上的C#编程技术。ASP.NET是由微软开发的一种Web应用程序框架,它整合了C#这种强大的编程语言,用于构建动态、交互式的网页和...

    Keil 入门实例教程

    Keil 是一款强大的嵌入式开发工具,尤其在微控制器(MCU)编程领域中广泛应用。本教程将带你深入理解Keil的使用,通过一系列实例,帮助你掌握其基本功能和高级特性。以下是对Keil及其入门实例教程的详细解析。 1. *...

    Windows驱动经典快速入门+驱动宝典

    本资源“Windows驱动经典快速入门+驱动宝典”是针对初学者设计的,旨在帮助他们快速掌握Windows驱动开发的基本概念和技能。以下是关于Windows驱动开发的一些核心知识点: 1. **驱动程序基础**:驱动程序是计算机...

    Linux 设备驱动程序设计入门

    《Linux设备驱动程序设计入门》是一本面向初学者的教程,特别适合那些对Linux系统有一定了解,希望深入学习设备驱动程序开发的读者。在RedHat9这个稳定的Linux发行版上进行实践,使得这本书中的示例和操作具有较高的...

    C++入门基础教程--全套

    C++是一种强大的、通用的编程语言,被广泛应用于系统软件、应用软件、游戏开发、设备驱动程序等各个领域。作为初学者,理解并掌握C++的基础至关重要。本套" C++入门基础教程--全套 "旨在为新手提供全面的C++学习路径...

    C语言程序设计入门教程ppt

    **C语言程序设计入门教程** C语言是一种强大的、低级的编程语言,广泛应用于系统开发、软件编程、设备驱动编写等多个领域。对于初学者来说,理解C语言的基础知识至关重要,因为它是许多现代编程语言的基础。这份...

    Proteus 入门教程.pdf

    ### Proteus 入门教程详解 #### 一、Proteus 软件概述与界面介绍 Proteus是一款强大的电子电路设计与仿真软件,它包括两大组件:ISIS(电路原理图绘制)和ARES(PCB设计)。Proteus ISIS提供了一套完整的电路原理...

    kisssys入门实例教程3.pdf

    在接下来的内容中,我们将详细了解KISSsys入门实例教程3.pdf的内容,该教程主要介绍了如何使用KISSsys软件对行星轮系进行建模、设置和仿真实例。 首先,教程分为两个部分,需要按照顺序进行学习。第一部分是引言,...

    JavaScript+jQuery网页特效设计任务驱动教程-PPT.zip

    JavaScript和jQuery是网页开发中的两种重要工具,它们在创建交互式和动态网页特效方面发挥着核心作用。...无论你是初学者还是有一定经验的开发者,这都将是一份有价值的参考资料,帮助你在网页开发领域更上一层楼。

    组态王教程 基础,入门级 高手可以绕道

    ### 组态王教程知识点详解 #### 一、组态王软件概述 - **软件定位**:“组态王”是一款专用于工业自动化领域的组态软件,适用于Microsoft Windows 98/NT中文操作系统平台,具备全中文界面,方便国内用户理解和使用...

    Verilog入门和高级教程

    5. **约束驱动设计**:使用IEEE 1800 SystemVerilog扩展,通过约束来指定设计参数,简化设计流程。 通过本教程,你将能够掌握Verilog的基本概念,编写简单的数字逻辑设计,并逐步进阶到高级技巧,包括综合、验证和...

    西门子WINCC入门级

    本“西门子WINCC入门级”教程旨在帮助初学者快速了解并上手这款软件。通过48集的视频教程,你可以学习到以下核心知识点: 1. **基本概念与界面**:了解WINCC的基本架构,包括项目管理、变量管理、画面设计、报警...

    ARM入门教程和入门手册

    **ARM嵌入式入门级教程** 这份PDF教程可能涵盖了以下几个核心主题: 1. **ARM架构基础**:介绍ARM的体系结构,包括处理器模式、寄存器布局、指令集架构(ISA)以及流水线概念。ARM架构通常采用RISC(精简指令集计算...

Global site tag (gtag.js) - Google Analytics