首页 星云 工具 资源 星选 资讯 热门工具
:

PDF转图片 完全免费 小红书视频下载 无水印 抖音视频下载 无水印 数字星空

主观与客观,破除DDD凭经验魔咒

编程知识
2024年08月28日 20:04

本文书接上回《学习真DDD的最佳路径》,关注公众号(老肖想当外语大佬)获取信息:

  1. 最新文章更新;

  2. DDD框架源码(.NET、Java双平台);

  3. 加群畅聊,建模分析、技术实现交流;

  4. 视频和直播在B站。

神秘的“凭经验”

一千个人眼中有一千个哈姆雷特,每个人的经历不同,认知不同,那么看待哈姆雷特的角度和感受也不同。在软件工程领域,也有著名的关于如何做好软件设计的观点:“凭经验”。然而,“凭经验”就意味着不可复制,如果软件设计只能凭经验,那还不如说是撞大运。

读过本系列前文《老肖的领域驱动设计之路》的朋友,应该知道,我对此是持相反的观点的,今天通过几分钟的篇幅,呈现我的理解,尝试破除凭经验的魔咒。

凭经验与主观判断

首先,我认为依靠经验来决策,本质上是一种主观判断,尤其是那些无法由客观事实和逻辑推导的判断和无法建立普遍共识的判断。至少凭经验这个方法本身,是主观的。试想一下,如果人们都仅仅依靠自己的过往经验来做判断,那么“靠左走好”和“靠右走好”就会成为普遍的观点冲突,而这个冲突的背后就是,“我不要你觉得,我要我觉得”。

当然更准确的说法是“凭经验”意味着不能绝对客观。

主观与客观

主观的反面是客观,客观意味着观点基于客观事实,基于符合事实的推导逻辑链,也就意味着客观决策,能够在一定的规则范围内建立共识的判断结果,那么我们可以得到如下观点:

  1. 主观判断对应非标,无法标准化

  2. 客观判断对应标准,可以标准化

如果对于一件事情可以标准化判断,是不是意味着这件事是可执行、可落地的?

需求分析和建模设计中的主观与客观

先举个例子,假设我们有个需求:“整理房间里的物品”,那么我们的解决方案可以是:“取N个收纳箱,把物品一个个放进去”,那么这里就有一些主观和客观的决策在里面。

主观的部分有:

  1. 决定用多少个收纳箱

  2. 哪些物品放哪个收纳箱

客观的部分有:

  1. 收纳箱之间相互独立

  2. 一个物品不会被放在两个收纳箱里

如果我们将物品和收纳箱对应到建模设计中,收纳箱里装物品,而软件是领域模型负责需求点的满足,则可以这样对应:

  1. 物品对应需求点

  2. 收纳箱对应领域模型

基于这样的对应,我们可以推导出我们在需求分析和建模时候,哪些部分是主观的,哪些部分又是客观的。

主观的部分:

  1. 有多少个领域模型

  2. 哪些需求点由哪个领域模型来满足

客观的部分:

  1. 领域模型之间相互独立

  2. 一个需求点不被两个领域模型来满足

回到领域驱动设计

如果你是跟着我的思路读到这里,并且认同前面的推导逻辑以及系列前文的核心观点“领域驱动是一种价值观”,这种价值观是“边界明确是最重要的事”,最精彩的部分来了,你会发现,我们前面推导出来客观的部分,是完全契合领域驱动设计价值观的。而主观的部分,甚至都不曾在领域驱动设计概念里提及。

所以,回到文章的开头关于凭经验的说法,我们认为软件设计中,凭经验的部分不会影响领域驱动设计价值观的践行。

那么我们的核心观点是,一个决策是否符合领域驱动设计,是可以客观判断的,领域驱动设计客观上可以落地执行,并不依赖人的经验

主观的部分不重要吗

我们再把建模时候主观的部分列出来:

  1. 有多少个领域模型

  2. 哪些需求点由哪个领域模型来满足

这部分当然也很重要,经验越丰富越容易更快速地定义出职责分配更准确的模型,但它不如“边界明确”这件事重要,因为“边界明确”解决的是结构性的问题,而主观的决策部分解决的是“局部准确性问题”,这就好比建筑里的“承重墙”和“隔间墙”之间的关系,显然承重墙决定了整体的架构,对建筑最终效果以及未来改造成本有更深远的影响。

后续

到此,《老肖的领域驱动设计之路》系列的整体逻辑已经接近闭环,下一期将从“反DDD”的视角来剖析软件行业的乱象,以及开发者可以努力的方向。

From:https://www.cnblogs.com/xiaoweiyu/p/18385539
本文地址: http://www.shuzixingkong.net/article/1531
0评论
提交 加载更多评论
其他文章 Prism:框架介绍与安装
Prism:框架介绍与安装 什么是Prism? Prism是一个用于在 WPF、Xamarin Form、Uno 平台和 WinUI 中构建松散耦合、可维护和可测试的 XAML 应用程序框架 Github https://github.com/PrismLibrary/Prism NuGet htt
Prism:框架介绍与安装 Prism:框架介绍与安装 Prism:框架介绍与安装
万丈高楼平地起:UML类图
UML类图 UML类图 是一种静态的结构图,描述了系统的类的集合,类的属性和类之间的关系,可以简化了人们对系统的理解。UML类图 是系统分析和设计阶段的重要产物,是系统编码和测试的重要模型。 图示 类 解析 圆角矩形框,它就代表一个类(Class) 类图分为三层: 第一层显示类的名称,如果是抽象类,
万丈高楼平地起:UML类图 万丈高楼平地起:UML类图 万丈高楼平地起:UML类图
国产化适配——人大金仓V8R6(1)
本文主要记录kingbase安装及存储过程修改相关内容,或有错漏,请指正。 原数据库:Mysql8.0.31 现数据库:KingbaseES V008R006C008M001B0030 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.8.5 20150
国产化适配——人大金仓V8R6(1) 国产化适配——人大金仓V8R6(1) 国产化适配——人大金仓V8R6(1)
Python开发工具:VSCode+插件
本篇是 Python 系列教程第 3 篇,更多内容敬请访问我的 Python 合集 Visual Studio Code的安装非常简单,就不放这里增加文章篇幅了。 相比PyCharm,VSCode更加轻量,启动速度快。并且搭配Python插件就能实现和Pycharm一样的代码提示、高亮效果。 1 安
Python开发工具:VSCode+插件 Python开发工具:VSCode+插件 Python开发工具:VSCode+插件
一个.NET开源、免费的跨平台物联网网关
前言 今天大姚给大家分享一个基于.NET开源、免费的跨平台物联网网关:IoTGateway。 项目介绍 IoTGateway是一个基于.NET6的跨平台物联网网关。通过可视化配置,轻松的连接到你的任何设备和系统(如PLC、扫码枪、CNC、数据库、串口设备、上位机、OPC Server、OPC UA
一个.NET开源、免费的跨平台物联网网关 一个.NET开源、免费的跨平台物联网网关 一个.NET开源、免费的跨平台物联网网关
入职后,我发现工作内容和自己想象中的不太一致。。
2018年6月,大三暑假进行时,实习第二天上班 昨天王工跟我说最好统一开发工具用eclipse,今早我瞄到其实也有同事用idea。 eclipse还得学习,用idea算了,随便上网找个盗版的就好咯,不纠结这么多。 公司被逮到,也是公司的问题,公司没有禁止使用idea,一定就不是我的问题。 一大早上班
入职后,我发现工作内容和自己想象中的不太一致。。 入职后,我发现工作内容和自己想象中的不太一致。。 入职后,我发现工作内容和自己想象中的不太一致。。
计算机Power电源状态
在计算机电源管理中,S1, S2, S3, S4 代表不同的电源状态或睡眠状态。 了解这些状态,对计算机设备理解功耗及工作状态有很大帮助。最近公司开会,系统同事有讲S3状态功耗很低,我猜和电脑的睡眠、息屏有关。。。emmm,不懂就要学 以下是这些状态的详细说明: S1 状态(低电量等待状态,又称“C
计算机Power电源状态 计算机Power电源状态
用我十多年的“奇葩”经验,给在“挂吊瓶”的博客园几点建议
初识博客园 我是08年开始接触开发的,一开始涉及的就是.net和java,记得那会好像是jar6来着,net嘛还是2.0 那时候包括现在,找资料很多时候会找到博客园来 一开始我以为博客园是很多博主成立的一个联盟,就是各自弄一个博客系统,然后公用一个域名 为啥会这么想呢? 因为我看高的博文都长得不一样
用我十多年的“奇葩”经验,给在“挂吊瓶”的博客园几点建议