`
raymond2006k
  • 浏览: 296091 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

领域建模实现思考

阅读更多
领域建模实现思考

“Javaeye论坛-领域建模”板块有很多讨论,不再引述,直接列举我的观点。

JavaEE中领域建模的困境包括:
1) 类膨胀。 需要职责理顺,分散和委托出去。
2) 无法摆脱Entity的Domain Service注入?

思路:
1. 目前的 Service 模式是一种组件化的,形式上是 OO 的,实质上是组件的,它能很好的解决现有问题。 但忽视了领域对象之前的天然关联性。

2. 领域模型特征: 普遍共识一般是Domain Object要求“ 数据 + 行为 ”的完整封装,对象实例的行为基于自己的数据,对象之间存在数据关联(Data Association)和行为关联(Behavior Association)。此外领域对象还能响应事件。
一个应用的领域对象依据其相互关联,可由一个根对象(Root Model) 导航获取到任何一个的Domain Object。

因此一个完整的领域模型可以抽象为:
Domain Model = Data +  Association + Behavior + Event

3. 恰当平衡领域建模思想和实践的冲突。
第一个问题:如类膨胀,就是谈的很多的充血问题。随着系统发展,一个Domain Object要承担的Behavior增多,代码中的Method增多,导致文件庞大。 这更主要是一个实现阶段的问题,但不能不认真考虑。

解决充血肯定要反向思考,即给对象“放血”。将行为分散,实现角度需要增加Behavior类或接口,协同构建Domain Model。

Qi4j 框架基本实现了这一点,Domain Object设计和方法定义完全靠 Interface 和 Interface继承; 方法实现类为Mixin,只关注它要实现的Interface,子类为Composite模式,实现了很好的放血和分散。
如:
Domain Object 定义
public interface Speaker
{
    String sayHello();
}


方法实现
public class SpeakerMixin
    implements Speaker
{
    public String sayHello()
    {
        return "Hello, World!";
    }
}


子类(应该说是接口)定义
@Mixins( SpeakerMixin.class )
public interface PoliticianComposite extends Composite, Speaker  // +others
{
}


但Qi4j 还有Concern等很多概念,看它的范例代码,感觉巨复杂,大量用了Annotation,不很喜欢。

3) 领域建模对使用者(程序员)要简单,友好。
现有框架太多的EJB,Service,DAO等框架要求的类,分层清晰,但导致代码增多,开发量和使用难度增加。当然,因为这种架构设计的清晰,规范性,在实践中获得了很大成功,功劳不可忽视。
新一代的开发框架,如果要面向“领域驱动设计”,需要将 Service,DAO,VO等概念进行融合,实现Data 和Behavior的重新聚合,而且Behavior不管它是原子性的CRUD,还是粗粒度的Business Method。

4) 类设计思路1:Behavior类继承 Data 类,这样使用者面对的是数据和Behavior统一的对象实例;
5) 类设计思路2:Domain Object恰当划分Sub Domain, 避免Behavior膨胀。

6) 类设计思路3:1关联的对象( order.customer ) 既有数据,又有Behavior,不存在什么问题,Hibernate等已经很好支持; 但N关联的对象( 如:user.orders ) 是一个集合(Collection)仍是以Data Model为中心;需要变为以“Behavior + Data Model”为中心,重点在Behavior;需要一个集合对Element成员有CRUD操作, 特别是更业务性的操作。


7) 跨环境( Context )问题。
一个Domain Object 在一个系统的不同子系统,不同领域有不同的Data Model和Behavior,因此对Domain Object需要按Context 进行关注。
一个基类如Person如果在不同Context有不同的表现,Manager,Employee,Sale,Clerk等,就需要按各自 Context 设计,而不能单线继承的设计。

思考的编程模型:
Category extends CategoryDO {
	void deleteProduct(String productId); 
 }

Category category = Categorys.find("sss");
  category.getId();
  
  category.deleteProduct("xxxx");
  
  category.getProducts().delete("sss");
  
  category.getProducts().add("ddddd");
  
  category.getProducts().query("xxxx");


[参考资料]
1. Robbin  domain model的延伸讨论 http://www.iteye.com/topic/57075
2. Taowen 贫血的Domain Model http://www.iteye.com/topic/191261
3. Taowen 再论领域模型的困境  http://www.iteye.com/topic/401223
4. Lifethinker 一个简单例子:贫血模型or领域模型 http://www.iteye.com/topic/283668
5. javaboy2006 基于DDD项目的设计总结 http://www.iteye.com/topic/351597


分享到:
评论
5 楼 unsid 2009-07-17  
根本就没有一个人站出来充当领域专家,Eric Evans说没有领域专家的领域驱动设计是荒谬的
4 楼 fenxue 2009-07-16  
是啊,感觉领域模型不能脱离实际业务去空谈,建议LZ能够拿个实际的业务场景,大家一起探讨才更有意义.
3 楼 treblesoftware 2009-06-20  
我感觉领域模型的问题更多是非技术问题,而是对那个领域的了解,哪些可以被封装,因为对需求的理解,所以可以产生良好的OO设计,既然模型才能发挥出真正的威力。
2 楼 raymond2006k 2009-06-20  
领域建模有几个层次:分析,设计,和实现。

分析,设计阶段的领域建模的理论,特别是DDD,相对实现层面比较成熟了。Eric Evans 等大家的著作,文章和观点从 javaeye 里的讨论看没有很大的疑议。

taowen,robbin 等很多同学,大家探讨的应该是实现层面的领域建模,我也是很关注这个方面。说白了就是怎样在编码上较为完美,优雅的体现Domain Model思想,如何设计一个Framework 来具体实施这种思想。正如 Qi4j,还有taowen 同学在google code上的项目, 我自己也在思考和尝试这些研究。

所以,DDD着重分析,设计,大家并没有抛开这个认知;
我们关注coding,framework,如何消除或隐匿 BO,DAO,回归 OOP,让Domain Modeling 最终落地, 这并不冲突。

所以,领域建模不单是个理论性的问题,同样是个技术问题。只是大家关注层面不同而已。
1 楼 unsid 2009-06-18  
说实在的,Eric Evans真正把领域驱动设计作为一个广为流传的概念,不从原著中寻找线索说不过去。《DDD》那本书其实我觉得最重要就是前几章,现在很多人抛开对领域建模的认知而技术化的谈论这个问题,倘若你没有时时刻刻保持对领域模型和统一语言的意识,别指望那些领域对象会为你带来任何效率上的提高。说白了,技术好实现,意识难达到,一个非技术性主导的技术问题。

相关推荐

    2013数学建模国赛B题思考过程和模型还有代码(适合初学者)

    在数学建模领域,2013年的全国数学建模竞赛B题是一个具有挑战性的议题,对于初学者来说,这是一个极好的学习资源。本解答集全面涵盖了从问题理解、模型构建到编程实现以及论文写作的全过程,对于提升建模技能极具...

    领域驱动设计(完整清晰版).part4.rar

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    领域驱动设计:软件核心复杂性应对之道

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    领域驱动设计(完整清晰版).part3.rar

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    领域驱动设计.软件核心复杂性应对之道 PDF Part5

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。 本书就是为此目的而编写...

    领域驱动设计.软件核心复杂性应对之道 PDF Part1

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。 本书就是为此目的而编写...

    领域驱动设计.软件核心复杂性应对之道 PDF Part4

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。 本书就是为此目的而编写...

    领域驱动设计.软件核心复杂性应对之道 PDF Part3

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。 本书就是为此目的而编写...

    领域驱动设计(完整清晰版).part7.rar

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    领域驱动设计(完整清晰版).part5.rar

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    领域驱动设计.软件核心复杂性应对之道 PDF Part2

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。 本书就是为此目的而编写...

    领域驱动设计(完整清晰版).part2.rar

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    领域驱动设计(完整清晰版).part6.rar

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    领域驱动设计(完整清晰版).part1.rar

    通过领域建模,软件开发人员能够展示丰富的功能并将这些功能实现为真正满 足用户需要的软件。尽管领域建模非常重要,但市面上介绍如何将有效的领域建模结合到软件开发过程中的著作却非常少。  本书就是为此目的而...

    Android架构师手册_建模与图形思考_04

    在IT行业,尤其是软件开发和架构设计领域,图形语言与图形思考能力正日益凸显其重要性和价值。根据《Android架构师手册_建模与图形思考》(By 高煥堂2012)的阐述,图形语言不仅包括文字,还涵盖了影像、符号和数字...

    数学建模原赛题及实现方案优秀论文

    在数学建模领域,原赛题及实现方案的优秀论文是至关重要的学习资源,它们能够帮助参赛者理解和掌握数学建模的基本步骤、方法以及如何构建有效的解决方案。本资源集合包含了2006年至2016年十年间的美国数学建模竞赛...

    基于混合高斯模型背景建模法来检测运动目标算法(matlab).zip

    混合高斯模型(GMM,Gaussian Mixture Model)是一种概率模型,常用于统计建模,特别是计算机视觉领域中的背景建模与运动目标检测。在本项目“基于混合高斯模型背景建模法来检测运动目标算法(matlab).zip”中,我们...

    现代数据栈与数据建模思考共24页.pdf.zip

    本资料"现代数据栈与数据建模思考共24页.pdf.zip"深入探讨了这两个主题,下面将对它们进行详细的解析。 首先,现代数据栈通常包括以下几个核心组件: 1. **数据源**:这是数据的起点,可以是各种在线和离线系统,...

    数学建模存储模型

    存贮模型在生产和存储领域具有重要的应用价值,通过构建合理的数学模型,可以帮助企业降低生产成本,提高资源利用率,从而实现利润最大化的目标。无论是不允许缺货模型还是允许缺货模型,都旨在通过优化生产周期和...

    沈继红 数学建模.rar

    数学建模是一种将现实世界中的复杂问题转化为数学语言...该书适合从事科研、工程或数据分析等领域的专业人士阅读,也适合数学建模竞赛选手参考学习,通过学习和实践提升数学建模能力,培养出解决实际问题的能力和素养。

Global site tag (gtag.js) - Google Analytics