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

简介:

阅读本文需要有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所涉及的事实外,还应该表示出软件使用者与软件之间的整个交互事实;
 
那么大家觉得哪个才是软件需要实现的真谛呢?呵呵,就这么多吧,话不多,但都是我深刻思考后的东西。希望大家也谈谈各自的看法。 

目录
相关文章
|
8月前
|
前端开发 JavaScript 开发者
《解锁CSS Flex布局:重塑现代网页布局的底层逻辑》
CSS Flex布局(弹性盒子布局)是现代网页设计中的重要技术,彻底革新了传统布局方式。它通过“容器”与“项目”的概念,提供灵活的空间分配与排列规则,轻松实现水平/垂直居中、等高列、响应式布局等复杂需求。相比传统方法,Flex布局代码简洁高效,显著提升开发体验与页面适应性。然而,浏览器兼容性及对极复杂场景的支持仍需注意。作为网页布局的核心工具之一,Flex布局推动了用户体验与设计创新的进一步发展。
147 13
|
9月前
|
存储 运维 监控
提升Windows Server环境安全性:ADAudit Plus的五大关键优势
在Windows Server环境中,内置的安全审计工具虽有用,但存在专业门槛高、耗时及功能缺失等问题。第三方工具ADAudit Plus应运而生,其五大优势包括:日志聚合、关键活动检测、定制化报告、灵活安全配置和长期日志保留,有效提升系统监控与合规能力。选择ADAudit Plus,助力企业更高效应对审计挑战,强化安全性。
213 2
|
开发者
Harmony 状态管理神器 @ObservedV2
Harmony 状态管理神器 @ObservedV2
250 4
Harmony 状态管理神器 @ObservedV2
|
程序员 调度 开发工具
DOS系统
【10月更文挑战第15天】DOS系统
656 3
|
关系型数据库 MySQL 测试技术
MySQL外键使用的考量与建议
综上所述,虽然MySQL的外键提供了一种强大的工具来维护数据之间的一致性和完整性,但在决定是否使用外键时,需要权衡其带来的好处和潜在的性能影响。通过仔细的规划和测试,可以最大化地利用外键的优势,同时避免一些常见的陷阱。
390 1
|
JavaScript 前端开发 数据安全/隐私保护
JavaScript 实现的base64加密、md5加密、sha1加密及AES加密
1. Base64加密 1). js-base64 2). 安装 npm install --save js-base64 3). 使用 // 加密 var str = Base64.
2841 0
|
Java 测试技术 监控
『StabilityGuide』| 10+位阿里技术专家共同发起稳定性知识库开源项目
我们穿过山和大海,也见过人山人海。我们见过各类故障,也排过千雷万险。这一次,不如我们一起,开启稳定性的探索之旅。让无法解决的问题少一点点,让世界的确定性多一点点。 无论是前端业务的开发者,还是后端架构的开发者,都会遇到业务稳定性的难题。
6255 85
|
机器学习/深度学习 缓存 架构师
十年技术进阶路,让我明白了三件要事(8000字长文)
8000字长文,大概花费您10分钟的阅读时间,我将以十年成长道路与八年写博经历分享与你,希望能给予各位读者或多或少的建议与提醒
713 1
十年技术进阶路,让我明白了三件要事(8000字长文)
|
SpringCloudAlibaba Cloud Native Dubbo
【云原生】Spring Cloud Alibaba 之 Feign 远程调用 实战
分布式系统下远程调用该如何选择?RestTemplate 与 Feign,Feign是最佳选择!
1059 0
【云原生】Spring Cloud Alibaba 之 Feign 远程调用 实战
|
Android开发
Android 选择图片、上传图片之PictureSelector
Android 选择图片、上传图片之PictureSelector
1587 0
Android 选择图片、上传图片之PictureSelector