分类 标签 存档 订阅 搜索

领域模型中的充血模型

0 浏览0 评论

本文来源领域模型中的充血模型

本篇笑点

我要从甲方跳到乙方公司了。
被我领导知道了

你得知道这篇讲的些什么

本文1229字,阅读可能需要2分23秒

与贫血模型不一样的充血模型

说明

继续上一篇 回头看领域模型中的贫血模型继续来看一下不一样的充血模型。

充血模型

充血模型贫血模型差不多,所不同的就是如何划分业务逻辑,即认为,绝大多业务逻辑都应该被放在domain object里面(包括持久化逻辑),而Service层应该是很薄的一层,仅仅封装事务和少量逻辑,不和DAO层打交道。

在贫血模型中,数据和业务逻辑被分割到不同的类中。充血模型(Rich Domain Model)正好相反,数据和对应的业务逻辑被封装到同一个类中。因此,这种充血模型满足面向对象的封装特性,是典型的面向对象编程风格。

包结构

充血模型的实现一般包括如下包:

内容
model 包含了实体类信息,还包含原子服务和数据持久化的逻辑
service 放置所有的服务类 组合服务 也叫事务服务
代码实现

先看model包的两个类,Account和TransferTransaction对象,分别代表帐户和一次转账事务。由于它们不包含业务逻辑,就是一个普通的Java Bean,下面的代码省略了get和set方法。

/**
 * 账户
 **/
public class Account {  
    private String accountId;  
    private BigDecimal balance;  
  
    public Account() {}  
    public Account(String accountId, BigDecimal balance) {  
        this.accountId = accountId;  
        this.balance = balance;  
    }  
    // getter and setter ....  
  
} 
/**
 * 转账
 **/
public class TransferTransaction {  
    private Date timestamp;  
    private String fromAccountId;  
    private String toAccountId;  
    private BigDecimal amount;  
  
    public TransferTransaction() {}  
  
    public TransferTransaction(String fromAccountId, String toAccountId, BigDecimal amount, Date timestamp) {  
        this.fromAccountId = fromAccountId;  
        this.toAccountId = toAccountId;  
        this.amount = amount;  
        this.timestamp = timestamp;  
    }  
  
    // getter and setter ....

/**  
  * 转账逻辑  
  * @param fromAccountId 转账人  
  * @param toAccountId 收账人  
  * @param amount 金额  
  * @return  
  * @throws AccountNotExistedException  
  * @throws AccountUnderflowException  
  */
 public TransferTransaction transfer(String fromAccountId, String toAccountId,  
  BigDecimal amount) throws AccountNotExistedException, AccountUnderflowException {  
    Validate.isTrue(0 < amount.compareTo(BigDecimal.ZERO));  
      //业务逻辑略...
  
	  // 调用DAO进行显式持久化
	  return new TransferTransactionDAO().create(fromAccountId, toAccountId, amount);  
 }  
} 

发现没有 在这种模型中,所有的业务逻辑全部都在TransferTransaction 中,事务管理也在TransferTransaction 中实现。

这种模型的优点:
1、更加符合OO的原则
2、Service层很薄,只充当Facade的角色,不和DAO打交道。

缺点也很明显
1、当model中包含了数据持久化的逻辑,实例化的时候可能会有很大麻烦,拿到了太多不一定需要的关联model。

总结

所谓充血模型的思想 无非是要就是要大家不要盲目写代码不要盲目的一撸到底 要从全局设计出发 设计清楚了再开工

附言

本篇如有错误,请及时指出,马上修改。

非常非常重要的事情

本文首发于【黑壳博客】,文章持续更新,可以微信搜索【黑壳博客】点个关注 文章第一时间阅读。

黑壳博客 blog.bhusk.com

E-mail:[email protected]

本文由 黑壳博客的壳叔 创作或转载,采用 知识共享署名 3.0 中国大陆许可协议 进行许可。

可自由转载、引用,但需署名作者且注明文章

评论  
留下你的脚步
推荐阅读