热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

领域驱动设计的思考

零散记录,随想随记,在适当的时候再做整合:问题一:对于数据或输入参数的校验应该放到应用层还是领域层?在编写程序时,少不了对输入参数的校验。第一可以减少异常场景,另外也可以节省不必

零散记录,随想随记,在适当的时候再做整合:

问题一:对于数据或输入参数的校验应该放到应用层还是领域层?

在编写程序时,少不了对输入参数的校验。

第一可以减少异常场景,另外也可以节省不必要的执行逻辑,从这个角度讲参数的校验应该尽量靠前,如果参数是异常的话,应该尽早返回给调用方,所以放在应用层的最前端比较合适。

但如果把参数合法性理解成为领域对象的行为,也就是说领域对象是最了解输入参数校验规则的,那么就应该把参数校验逻辑放在领域层。并且,对于调用领域对象的调用方来说,这样是安全可靠的,同时也减少了重复校验的可能性。

结论:不是原则性问题,可以通过定于规范来统一行为,但是一定要有地方定义参数的校验逻辑,无论是在接口文档,还是在领域对象的注释中,并且保证这是唯一定义参数校验逻辑的地方。

问题二:对于事务的控制应该放在哪里?

比较重要,核心的问题。事务的定义:是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。

有几条原则:1. 聚合根首先是原子的,即聚合根内部的操作是原子的;

结论:目前看,事务应该放在应用层来做,由应用层来统一规划事务的范围,毕竟事务的范围是由业务最终决定的。

问题三:领域边界如何界定?

之前一直在纠结一个问题:两个系统交互时,可能会用到同样的对象,例如A系统调用B系统获取User信息,A和B系统都需要定义User的数据结构,那么这个User的数据结构是分别由A和B分别维护,还是在一个Common包中维护?

如果由A和B分别维护,则当User发生变化时,A和B要协调同步修改,这里可能存在没有同步的问题;如果在Common包中维护,而A和B对User的定义有可能不完全一样,所以还需要在A和B中分别再创建UserA和UserB,以区分两者的不同,产生了冗余。

结论:需要结合具体场景来使用。如果把User单纯定义为传输结构的定义而不具备领域含义(即将其定义为应用层概念),那么在Common包中定义比较合适。但如果为了精简结构,User不仅作为传输结构,同时也包含领域意义(那么A和B对User的定义需要在各自的领域范围内赋能,其结构有相似但含义完全不同,比如A中是User,B中可能是Customer),那么就一定要由A和B分别定义了。





推荐阅读
  • 距离11月的软考还有不到五个月的时间,考试将于11月5日至6日举行。许多朋友对软考的具体情况还不太了解:它是什么?有何用途?本文将为你详细解答。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 本文总结了汇编语言中第五至第八章的关键知识点,涵盖间接寻址、指令格式、安全编程空间、逻辑运算指令及数据重复定义等内容。通过详细解析这些内容,帮助读者更好地理解和应用汇编语言的高级特性。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 优化版Windows 10 LTSC 21H2企业版:适用于低内存设备
    此版本为经过优化的Windows 10 LTSC 21H2企业版,特别适合低内存配置的计算机。它基于官方版本进行了精简和性能优化,确保在资源有限的情况下依然能够稳定运行。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 当iOS设备越狱后,某些插件可能会导致系统崩溃(白苹果)。此时,可以通过进入安全模式来排查并删除有问题的插件。本文将详细介绍如何通过特定按键组合进入不加载MobileSubstrate的安全模式,并提供相关背景知识。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 新冠肺炎疫情期间,各大银行积极利用手机银行平台,满足客户在金融与生活多方面的需求。线上服务不仅激活了防疫相关的民生场景,还推动了银行通过互联网思维进行获客、引流与经营。本文探讨了银行在找房、买菜、打卡、教育等领域的创新举措。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文探讨了如何在发布 XenApp 应用时,通过命令行参数实现启动时的参数传递。特别介绍了静态和动态参数传递的方法,并详细解释了 ICA 文件中两种参数传递方式的区别及安全检查机制。 ... [详细]
author-avatar
LoveCherryz
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有