专栏名称: 逸言
文学与软件,诗意地想念。
目录
相关文章推荐
今天看啥  ›  专栏  ›  逸言

从设计本质分析三种设计过程

逸言  · 公众号  · 程序员  · 2024-12-18 08:30
    

主要观点总结

本文对比了过程式设计、面向对象设计和领域驱动设计的差异,并分析了它们各自的优势和劣势。文章以业务软件编写为例,详细阐述了不同设计方式在处理CRUD操作时的特点,并重点介绍了领域驱动设计中的聚合概念。文章认为,对于U操作而言,如果通过建模得到的类遵循了“信息专家模式”,就能够让大量的业务逻辑集中到领域模型对象中,降低业务的复杂度,增加代码的可读性。

关键观点总结

关键观点1: 过程式设计与面向对象设计的比较

过程式设计注重数据结构+算法,面向对象设计则强调数据与行为的封装。在业务软件编写中,面向对象设计往往退而求其次,选择把数据建模与过程式设计结合起来,但实际上应该通过领域建模来更好地应对需求变化。

关键观点2: 领域驱动设计的优势

领域驱动设计通过引入聚合概念解决了面向对象设计对对象边界的不确定性问题。聚合规定了CRUD操作的边界,使得领域模型能够更好地应对业务复杂性。

关键观点3: C、R和D操作在领域驱动设计中的挑战

在领域驱动设计中,C(创建)、R(读取)和D(删除)操作存在与聚合边界的契合问题。虽然DDD通过聚合解决了一些问题,但在这些操作上并未体现出明显优势。

关键观点4: U操作在领域驱动设计中的优势

对于U操作(更新)而言,如果通过建模得到的类遵循了“信息专家模式”,就能够让大量的业务逻辑集中到领域模型对象中,增加代码的可读性,降低领域专家与开发团队的沟通难度。


文章预览

从本质分析过程式设计、面向对象设计和领域驱动设计,会有助于我们理解这三者之间的差异,并明确它们各自的优势,以便于更好地运用它们。 从最底层的本质来讲, 为所有业务型软件编写的业务代码都是对数据的增删改查(CRUD) 。只要属于业务逻辑的范围,没有什么业务操作可以超出这个范围。这或许是RESTful风格之所以将资源的操作归纳为GET、POST、PUT(含PATCH)和DELETE动词的主要原因。 过程式设计极为匹配CRUD操作,因为它的设计思想就是数据结构+算法,只要明确了CRUD的操作对象,就可以将该操作对象的数据封装到数据结构中,对它进行CRUD操作即可。 这一设计完全契合面向关系数据库的操作过程,关系表就是数据结构,CRUD就是SQL语句中的create、select、update和delete。实际上,SQL语句才是编写业务软件的世界语言,既然所有业务代码都是对 ………………………………

原文地址:访问原文地址
快照地址: 访问文章快照
总结与预览地址:访问总结与预览