贫血模型和DDD模型

贫血模型和DDD模型

1.贫血模型

1.1 概念

常见的mvc三层架构数据库

  • 简单、没有行为设计模式

2.领域驱动设计

2.1 概念(2004年提出的)

  • Domain Driven Design网络

  • 简称 DDD架构

  • DDD是一种以领域为核心的设计和开发理念。DDD经过维护一个深度反应领域概念的模型,以及提供了可行的通过实践校验的大量模式来应对领域的复杂性mvc

2.2 领域模型的特色

  • 对业务领域作了建模函数

    -- 细粒度的类,易于扩展,容易复用spa

    -- 能够应对复杂的业务逻辑设计

    -- 须要经验掌握对象

  • 简单的领域模型继承

    -- 几乎和数据库中的表一一对应

  • 复杂领域模型

    -- 使用了继承、组合、设计模式等各类手段

2.3 什么是领域

  • 收入确认

  • 机票预订

  • 金融

    。。。

2.4 通用语言

UML图、建模

2.5 DDD分层架构

  • 用户界面/展示层

  • 应用层

  • 领域层

  • 基础设施层

领域层就是把应用层的逻辑放到它这里

2.6 在领域层有什么东西

2.6.1实体

  • 惟一标志

    --对象不是由属性定义的,而是标志定义的

-- 对象内容的变化不会影响标识符

-- 不管保存到硬盘 ,装入内存,经过网络发送,标识符都不变

  • 除了标志外,哪些东西应该成为实体的属性?

    -- 抓住实体对象定义的最基本特征,用于识别,查找或匹配对象的特征

    -- 只添加那些对概念相当重要的行为和这些行为所需的属性

2.6.2 值对象(value Object)

-- 对象是根据值来肯定的

-- 能够在不一样的实体中使用

-- 值对象一般是不可变的

-- Color, Point ,Money...

2.6.3 领域服务

  • 有些领域逻辑是动词

-- 表示了一种重要的行为很难映射为对象,没法概括到实体和 值对象当中

-- 例如:转帐

  • 特征

    -- 服务执行的操做涉及一个领域概念,这个领域概念一般不属于一个实体或者值对象

    -- 被执行的操做涉及到领域中的其余的对象

    -- 操做是无状态的

  • 聚合(高内聚,低耦合就是这个意思)

    一堆对象组合有边界的服务

2.6.4 当构造一个复杂的对象时...

  • 怎么解决这些问题?

    -- 聚合的对象比较多

    -- 构造函数参数不少

    -- 逻辑很复杂

     

2.7 模型的分裂(针对大型复杂系统)

  • 领域

    --例如电子商务系统

  • 子领域

    -- 一个领域在逻辑思惟分离的部分

    -- 例如订单、产品目录、库存、发票

  • 界限上下文

    -- 领域模型所生产的边界

     

    1597722394972.png

相关文章
相关标签/搜索