读书笔记之---DDD(领域驱动设计)二
2008-08-21 17:42
615 查看
(DDD看过后的一些要点...)
模型驱动设计的基本构成要素:
实体--值对象--服务--模块--聚合--工厂--资源库
实体:有一类对象看上去好像拥有标识符,它的标识符在经历软件的各种状态后仍能保持一致,对这些对象来讲这已经不再是它们关心的属性,这意味着能够跨越系统的生命周期甚至能超越软件系统的一系列的延续性和标识符.这样的对象称为实体.
值对象:用来描述领域的特殊方面,且没有标识符的一个对象,叫做值对象.
区分实体对象和值对象非常必要.选择那些符合实体定义的对象作为实体,将剩下的对象处理成值对象.这会简化设计,并且将会产生某些其他的积极的意义.
如果值对象是共享的,那么他妈应该是不可变的.值对象应该保持尽量的简单.
服务的3个特征:
1.服务执行的操作涉及一个领域概念,这个领域概念通常不属于一个实体或者值对象
2.被执行的操作涉及到领域重的其它的对象
3.操作是无状态的
模块:对一个大型的复杂项目而言,模型趋向于越来越大.模型到达了一个作为整体很难讨论的点,理解不同不见之间的关系和交互变得很困难.基于此原因,很有必要将模型组织进模块.模块被用来作为组织相关概念和任务以便降低复杂性的一种方法.
聚合是一个用来定义对象所有权和边界的领域模式.
工厂和资源库是另外的两个涉及模式,用来帮助我们处理对象的创建和存储问题.
工厂用来封装对象创建所必须的知识,它们对创建聚合特别有用.当聚合的根建立时,所有聚合包含的对象将随之建立,所有的不变量得到了强化.
将创建过程原子化非常重要,如果不这样做,创建过程就会存在对某个对象执行了一半操作的机会,将这些对象置于未定义的状态,对聚合而言更是如此.
资源库:使用一个资源库,它的目的是封装所有获取对象引用所需的逻辑.领域对象不需要处理基础设施,以得到领域中对其它对象的所需的引用.只需从资源库中获取它们,于是模型重获它应有的清晰和焦点.
代码设计应该围绕模型展开,模型自身也会基于设计决定而有所增进.脱离了模型的设计会导致软件不能反映它所服务的领域,甚至可能得不到期望的行为.建模如果得不到设计的反馈或者缺少了开发人员的参与,会导致必须实现模型的人很难理解它,并且可能对所用的技术不太适合.
建模的的一件事是阅读业务规范,从中寻找名词和动词.名词转换成类,而动词则成为方法.将产生前层次的模型.
模型驱动设计的基本构成要素:
实体--值对象--服务--模块--聚合--工厂--资源库
实体:有一类对象看上去好像拥有标识符,它的标识符在经历软件的各种状态后仍能保持一致,对这些对象来讲这已经不再是它们关心的属性,这意味着能够跨越系统的生命周期甚至能超越软件系统的一系列的延续性和标识符.这样的对象称为实体.
值对象:用来描述领域的特殊方面,且没有标识符的一个对象,叫做值对象.
区分实体对象和值对象非常必要.选择那些符合实体定义的对象作为实体,将剩下的对象处理成值对象.这会简化设计,并且将会产生某些其他的积极的意义.
如果值对象是共享的,那么他妈应该是不可变的.值对象应该保持尽量的简单.
服务的3个特征:
1.服务执行的操作涉及一个领域概念,这个领域概念通常不属于一个实体或者值对象
2.被执行的操作涉及到领域重的其它的对象
3.操作是无状态的
模块:对一个大型的复杂项目而言,模型趋向于越来越大.模型到达了一个作为整体很难讨论的点,理解不同不见之间的关系和交互变得很困难.基于此原因,很有必要将模型组织进模块.模块被用来作为组织相关概念和任务以便降低复杂性的一种方法.
聚合是一个用来定义对象所有权和边界的领域模式.
工厂和资源库是另外的两个涉及模式,用来帮助我们处理对象的创建和存储问题.
工厂用来封装对象创建所必须的知识,它们对创建聚合特别有用.当聚合的根建立时,所有聚合包含的对象将随之建立,所有的不变量得到了强化.
将创建过程原子化非常重要,如果不这样做,创建过程就会存在对某个对象执行了一半操作的机会,将这些对象置于未定义的状态,对聚合而言更是如此.
资源库:使用一个资源库,它的目的是封装所有获取对象引用所需的逻辑.领域对象不需要处理基础设施,以得到领域中对其它对象的所需的引用.只需从资源库中获取它们,于是模型重获它应有的清晰和焦点.
代码设计应该围绕模型展开,模型自身也会基于设计决定而有所增进.脱离了模型的设计会导致软件不能反映它所服务的领域,甚至可能得不到期望的行为.建模如果得不到设计的反馈或者缺少了开发人员的参与,会导致必须实现模型的人很难理解它,并且可能对所用的技术不太适合.
建模的的一件事是阅读业务规范,从中寻找名词和动词.名词转换成类,而动词则成为方法.将产生前层次的模型.
相关文章推荐
- 读书笔记之---DDD(领域驱动设计)一
- 领域驱动设计 软件核心复杂性应对之道 读书笔记
- DDD 领域驱动设计-看我如何应对业务需求变化,领域模型调整?
- DDD领域驱动设计
- JavATE 0.6 支持Spring,领域驱动设计(DDD)框架
- 实战DDD(Domain-Driven Design领域驱动设计:Evans DDD)(转)
- DDD领域驱动设计(Domain Driven Design)(转)
- 领域驱动设计: Understanding DDD
- nhibernate中 领域驱动设计/开发(DDD,Domain Driven Design/Development)
- [.NET领域驱动设计实战系列]专题九:DDD案例:网上书店AOP和站点地图的实现
- 浅谈我对DDD领域驱动设计的理解
- DDD 领域驱动设计-谈谈 Repository、IUnitOfWork 和 IDbContext 的实践(1)
- DDD 领域驱动设计-两个实体的碰撞火花
- DDD(Domain Driver Designer) 领域驱动设计简介
- DDD -- 领域驱动设计 -- 到底啥叫“建模”?
- DDD领域驱动设计之领域基础设施层
- 搜集的关于领域驱动设计(DDD)的理论知识
- DDD 领域驱动设计-Value Object(值对象)如何使用 EF 进行正确映射
- [.NET领域驱动设计实战系列]专题九:DDD案例:网上书店AOP和站点地图的实现
- 【DDD】领域驱动设计实践 —— 架构风格及架构实例