热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

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

不知道本篇能否算作是入门级教程,因为大概构思了一下,里面有的是属于教程的东西,有的是相关的知识延伸,有的则什么都不是

  不知道本篇能否算作是入门级教程,因为大概构思了一下,里面有的是属于教程的东西,有的是相关的知识延伸,有的则什么都不是,就算是一点初级的认识吧,因为我也是接触不久。主要刚看完《领域驱动设计》,是一本不错的书。我看的是免费的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中介绍了一下《信息失真成本》。

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

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

 

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

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

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

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

  

  

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

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

转:https://www.cnblogs.com/virusswb/archive/2010/08/03/Domain-Driven-Development-1.html



推荐阅读
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文详细介绍了美国最具影响力的十大财团,包括洛克菲勒、摩根、花旗银行等。这些财团在历史发展过程中逐渐形成,并对美国的经济、政治和社会产生深远影响。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本次考试于2016年10月25日上午7:50至11:15举行,主要涉及数学专题,特别是斐波那契数列的性质及其在编程中的应用。本文将详细解析考试中的题目,并提供解题思路和代码实现。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 解决IIS无法访问映射网络驱动器的问题
    探讨IIS在尝试访问映射的网络驱动器时遇到的问题及其解决方案,包括配置和权限设置等方面的详细分析。 ... [详细]
  • 5G至4G空闲态移动TAU流程解析
    本文详细解析了用户从5G网络移动到4G网络时,在空闲态下触发的跟踪区更新(TAU)流程。通过N26接口实现无缝迁移,确保用户体验不受影响。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
author-avatar
西安黄河文化补习学校
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有