关于软件的任务到底是什么的思考

阅读本文需要有DDD,DCI的知识背景。 首先,我觉得软件是用来被用户使用的,也就是说软件是用来帮用户完成一些事情的。从下面的用例图可以很好的理解用户与软件的关系: 

 

上图是超市里的一个营业员处理一笔销售的一个用例。从这个用例我们可以清楚的看到营业员和系统之间的一个交互。从中我们可以清晰的得出系统该做什么:

makeNewSale

enterItem

makePayment

这三个操作可以理解为用户希望软件为她做的三件事请。最近我惊奇的发现,DDD和DCI的一个巨大差别,让我不得不拿出来和大家确认。那就是:

1)DDD强调软件不应该实现整个用例的交互过程,而应该只建立一个排除软件使用者的领域模型,该领域模型的目的不是要实现软件软件使用者与模型之间的交互过程,而是要捕捉和实现软件使用者提出的需求;

2)DCI强调软件应该实现整个用例的交互过程,在DCI的架构中,可能会有一个Person对象,然后扮演Cashier的角色参与到MakeNewSale或EnterItem等场景中去。

 

大家看到区别了吗?DDD更多的是把软件或者说把领域模型看成是一个“工具”,我们人类作为软件使用者通过使用这个工具来做一些事请;而DCI则是在模拟软件使用者与软件之间的整个交互过程,也就是说在DCI的架构中,我们能在内存中看到一个Cashier在做事情,就像现实生活中一样;而在DDD中,我们只会在内存中看到一些“物”在相互作用帮助软件使用者处理一些事情;简单的说:DCI是在完全模拟现实,而DDD则只侧重于表达除人之外的一个客观的“物模型”;

个人认为DDD的思想要比DCI好,因为虽然通过DDD思想建立出来的领域模型看起来是静态的,但我认为这恰恰是软件本质上该做的并且是只需要做的事情,事实上,我们都认为电脑是工具,我们建立领域模型目的也是为了用它,把它看成为一个工具而已。如果软件还要模拟人际交互的过程,那无疑会使软件(领域模型)不具有客观性。

其实很多时候想想,如果基于贫血模型的开发,那么软件只是一个帮助人类记录事实的工具,我们设计的对象没有任何行为,只是数据,就像数据库中的数据一样。事实上,数据库里存放的不是数据,而是事实的结果。比如数据库中有一条应聘记录,表示某个人在某个时候应聘过某个职位这个事实。所以,在贫血模型的开发模式下,我们的软件仅仅只是帮助我们记录事实的结果;

 

而在DDD等倡导的充血模型的开发模式下,对象不仅仅只是一个记录事实结果的工具,而是一个个活生生的能够拥有自己个体行为以及能够和其他对象交互的交互行为的对象。此时,对象不仅可以记录事实结果,而且可以表示事实发生的原因,即对象之间的相互交互协作,即这个事实结果是通过怎样的事实产生的,其实从更高的层面上理解,对象之间交互是一种正在发生的事实。因此,基于DDD思想的对象不仅可以表示事实的结果,还能表示事实本身,即对象交互。但这个交互没有包含软件使用者与软件之间的交互,而仅仅表示软件领域模型中各个具有一定客观性的对象之间的交互;

 

而在DCI的思想架构下,则认为软件除了要记录DDD所涉及的事实外,还应该表示出软件使用者与软件之间的整个交互事实;

 

那么大家觉得哪个才是软件需要实现的真谛呢?呵呵,就这么多吧,话不多,但都是我深刻思考后的东西。希望大家也谈谈各自的看法。 

时间: 2024-10-21 10:13:32

关于软件的任务到底是什么的思考的相关文章

提前认识软件开发(1) 序言

序言 正式踏上软件开发岗位已经将近两年了,经历了很多,也学到了很多."万事开头难",学生转变为职业人的过程,恰似茧化成蝶的过程. 1.为什么要写作本系列? 在工作的过程中,我发现我们在学校里面学到的很多东西片面肤浅,根本达不到岗位的要求.像编码规范.研发流程等等学校里几乎不提及的知识,在实际的软件开发项目中却恰恰是异常的重要. 在学校里面,我们欠缺的教育主要包括以下方面: 第一,对编码规范的要求.计算机编程课上,老师只要求学生能够编写程序实现既定的功能即可,几乎不会对编码规范提出要求,

软件工程师所需掌握的“终极技术”是什么?

最近,我在微博上看到@程序员邹欣老师发的一条微博 - "不少大学同学都有一个想法:先做几年技术,然后做管理:也有一些同学说:我技术不行,希望直接找到一个管理的工作,就像PM那样.请看 PM 需要什么样的能力:(链接略去)".在读这条微博的前一部分内容时,我的第一反应是:难道同学们以为做技术管理不需要很好的技术功底?刚好在此之前,我写过<技术敏感度 - 基层技术管理者必备>一文,强调技术功底对于基层技术管理者的重要性.于是,我对该条微博评论了:"建议邹老师建议他们好

抢票软件哪个好

  一年一度的国庆来了,一年一度的抢票怎么会缺席,购买一张回家过年的火车票我们永远都要抢!在这里介绍一下各抢票软件哪个好用,几个抢票浏览器都怎么样,做个比较,让大家在购买火车票时可以参考选择. 方法一.登录比较 1.猎豹浏览器抢票软件,登录界面还是用了12306官方的登录.并且可以自行选择是否记录密码. 2.数字公司够狠,登录的时候已经看不出12306的样子了,只是让你输入12306的帐号密码. 3.下次登录时,密码自动填充,数字公司帮你记住了密码.暂时没看到不让它记的办法. 4.在登录时,两个

软件开发-这个项目需要多少钱才能开发?

问题描述 这个项目需要多少钱才能开发? 我是基层气象局的工作人员,我希望找公司开发底层数据库.但是我真的搞不懂,现在的软件开发项目到底需要多少钱! 我把自己想的东西列了一下,有没有人可以指点下,需要多少钱.如果可能的话,还想知道需要多少时间. 我自己99年毕业的通信工程专业,数据库还懂一点,应当可以配合开发人员的. XX县数据共享平台任务书 一. 数据的汇集 a) 实现从省市自动站数据库自动获取.归集XX县所有测站的实时观测资料 b) 从省局数据库导入XX县本站及中尺度站的历史资料(资料来源由X

国际信息处理联合会候任主席Mike Hinchey:软件将定义一切吗?

5月18-20日,由中国电子学会主办,ZD至顶网协办的第八届中国云计算大会在北京国家会议中心隆重举办.在20日上午的主会场中,来自国际信息处理联合会的候任主席Mike Hinchey先生为我们带来了主题为"软件将定义一切吗?"的精彩演讲. 国际信息处理联合会候任主席 Mike Hinchey 先生 Mike Hinchey在演讲中就软件定义对云计算.大数据以及空间技术等领域所起到的重要作用给出了自己的理解.他讲到:"我们有一个空间系统的项目,针对飞行器我们可以帮助他们来优化计

让你提前认识软件开发(1):序言

序言           正式踏上软件开发岗位已经将近两年了,经历了很多,也学到了很多."万事开头难",学生转变为职业人的过程,恰似茧化成蝶的过程.          1.为什么要写作本系列?        在工作的过程中,我发现我们在学校里面学到的很多东西片面肤浅,根本达不到岗位的要求.像编码规范.研发流程等等学校里几乎不提及的知识,在实际的软件开发项目中却恰恰是异常的重要.        在学校里面,我们欠缺的教育主要包括以下方面:        第一,对编码规范的要求.计算机编程

重构与再造:软件创新与未来制造

当我们把制造业与工业软件放在一起讨论时大家最先想到的是制造业信息化的问题,现在我们国家的工业软件信息化已经走过了终端普及.网络普及的阶段,正在向与软件业深度融合这一阶段发展.所以工业软件如何创新新的产品.为制造业提供怎样的解决方案,这成为与工业软件向制造业渗透并改进制造业服务商业模式的关键. 数字化转型:数字的竞争力是关键 数字化转型过程当中,数字的竞争力就成为竞争的焦点.围绕数字化转型和数字化竞争,推动了一系列的重大的举措.制造业发展,已经不是过去简单的机械化.自动化.信息化的时代,而是高度的

全网销量第一 腾云连锁酒店管理软件五折惊爆价

中介交易 http://www.aliyun.com/zixun/aggregation/6858.html">SEO诊断 淘宝客 云主机 技术大厅 酒店管理系统软件已经成为酒店企业必备的管理工具,能够为酒店带来在营销.管理.服务质量等方面的好处,提升企业工作效率,更加科学高效管理. 连锁经济酒店越来越受青睐,什么样的酒店管理软件适合连锁型酒店呢? 只要一离开,酒店的运营状态,财务数据,异动报表等情况无法随时随地掌控,怎么办? 酒店人员流动量大,导致前台工作频繁中断,如何解决? 如今,市场

国内领先招财猫进销存软件 年中促销限量抢购中

中介交易 http://www.aliyun.com/zixun/aggregation/6858.html">SEO诊断 淘宝客 云主机 技术大厅 进销存软件,被誉为企业管理中的主流程,中小企业必备工具!随着市场经济的大力发展,中小型企业.零售.店面的数量不断增多,产品种类丰富,产品流动过程中的工作变得繁重,很多卖家.企业就利用进销存软件来管理进帐.销售和库存数目等,提升工作效率. 市场数不尽的进销存软件蜂拥而至,到底哪一款进销存管理软件最好用? 招财猫作为一款专业为中小企业,个体商铺开