安徽新华电脑专修学院_安徽电脑培训_安徽电脑培训学校_合肥电脑培训

當前位置:首頁 > 網站舊欄目 > 學習園地 > 設計軟件教程 > 談一談貧血的Domain Logic問題。

談一談貧血的Domain Logic問題。
2010-01-14 22:28:10  作者:  來源:
如今采用Hibernate實現的Domain Model,多數只是維護實體之間的關聯,而大多數的業務邏輯,則是由Service Layer來實現。

這樣的模型對象擁有的行為太少了,以至于Martin Fowler給他們下了一個定義:貧血模型。

我們知道,高內聚低耦合是衡量一個模型設計是否合理的重要標準之一。對象組件間合理分工協作可以解決復雜的問題邏輯,按照這個標準,我們似乎可以很自然的各種行為封裝到各個模型對象中。 然而,現在絕大多數的應用沒有這樣做。

ORM作為模型對象與數據庫模型之間的接口,它的引入無疑承擔了實體領域模型所能稱之為領域模型的 所有責任。 正如同Martin Fowler所說的,貧血的領域模型承擔了領域模型的所有成本,卻沒有得到真正的收益。
在這里,真正的收益應該是指高內聚低耦合的擁有復雜對象行為的領域模型,確實,我們設計的領域模型根本沒有實現任何的功能,我們只能在外面從新設計一個 Service Layer來管理所有的行為。

我不敢評論這樣的設計方案是怎樣的不合理。 當設計到擁有比較復雜問題領域模型的時候,這種只負責管理實體間關聯關系的實體模型肯定不能適應,這樣做的后果就是將復雜領域邏輯統統 移植到 Service Layer層或者胡亂給起名字的一個外層。

考慮Martin Fowler 《Analysis Patterns》中著名的一個通用模型:團體責任模型。里面的約束需要在實體領域模型中得以實現,在貧血領域模型中,封裝實現這樣的需要檢索 驗證某個甚至全部實體數據的行為只能移植到Service Layer中。 這樣的移植對于領域模型的構架無疑大大增加了復雜度。


那么,我們能不能在貧血領域模型基礎上,加入對象行為,使之擁有豐富的行為呢? 我想這是可以解決的,解決的關鍵是將可訪問底層實體數據的行為賦予每一個實體模型對象,最簡便的辦法就是用一個全局訪問點來實現。

考慮這么一個層次:
Java代碼 復制代碼
  1. public interface ServiceProvider{   
  2.                 public Object getService(String serviceName);;   
  3.           
  4. }   
  5.   
  6.   
  7. public ServiceProviderImpl{   
  8.               public ObjectgetService(String serviceName);{   
  9.                 
  10.                     return ServiceLocator.getService(serbiceName  );;   
  11.              }   
  12.                   
  13. }   
  14.   
  15. public interface CRUD{   
  16.      public void save();;   
  17.       public void delete();;   
  18.        public void load(Long id);;   
  19.       public void update();;   
  20. }   
  21.   
  22. public Group implements CRUD {   
  23.   
  24.     private String name;   
  25.      private List  users;   
  26.       public GroupService getGroupService();{   
  27.            return (GroupService);getServiceProvider();.getService(this.class.getName();+"Service");   
  28.       }   
  29.      public void save();{   
  30.           if(getGroupService();.findGroupByName(name);!=null);   
  31.                        throw new RuntimeExepion("duplicate group name!");;   
  32.           getGroupService();.save(this);;   
  33.       }   
  34.       public  Group load(Long id);{   
  35.            this=getGroupService();.load(this.class,id);;   
  36.            return this;   
  37.       }   
  38.          
  39.      public void addUser(user user);{   
  40.                 
  41.             users.add(user);;   
  42.             this.save();;    
  43.         
  44.     }   
  45.      public void removeUser(User user);{   
  46.      }   
  47.   
  48.         
  49.   
  50. }  

這樣作的問題是與建立貧血對象模型相比,領域對象模型的行為通用需要ServiceLayer來完成,約定:
1)ServiceLayer層只負責實現簡單的單步驟的與底層數據庫訪問的 邏輯,不包含任何業務領域邏輯。 如上面的 service.save(),service.update, service.delete , service.findGroupByName.... 

2) 領域模型對象負責對自身的領域邏輯進行封裝。

3)通過賦予模型對象行為,建立對象間行為關聯,以完成更復雜的 商業邏輯。

4)外層業務邏輯層只能看到領域模型對象,不能直接操作任何的類似Service.save這樣的直接訪問底層數據庫的行為。

安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢
主站蜘蛛池模板: 日本国际高中学校招生【立学仕日本留学服务】日语中学学校|美术生|艺术生|高中生|本科|研究生|语言学校留学择校申请 | 直冷式块冰机|片冰机|块冰机|制冰机厂家|深圳市冰之星制冷科技有限公司 | 开关柜无线测温_电缆接头测温系统_六氟化硫sf6气体泄漏报警监测_卫星同步时钟-山东正瑞电子有限公司 | 浙江民数科技有限公司| 叛逆孩子改造,青少年行为矫正,戒网瘾学校,特训学校,全封闭军事化管理学校 | 嘉兴市南湖斋食品股份有限公司_南湖斋| 宁波允泰仪器有限公司-硬度计、拉力试验机、盐雾试验箱、影像测量仪、气动量仪 | 上海海外置业展_2024海外置业移民留学展_4月5-7日_企业参展处/免费领门票 | 莱湾科技-智能会议室|多功能|多媒体|音视频|无纸化|远程视频会议室运维 | 深圳家具网-家具展会-家具检测-家具品牌—深圳市家具行业协会官网 | 轮转印刷机_商标印唛机_超声波切唛机_瑞安市明辉机械有限公司 | 湖南净声源环保科技有限公司是一家专业从事噪声治理和建筑声学设计生态环境综合治理服务的企业,专业从事株洲电梯隔音治理,湘潭中央空调降噪处理,衡阳邵阳冷却塔噪音治理,岳阳常德大型风机噪声隔音降噪,张家界空压机噪声治理,益阳配电房变压器噪声治理,专业郴州永州工厂企业车间噪声治理,怀化娄底专业机械设备减振降治理,武汉噪音治理隔音降噪公司,孝感噪音治理,立式球磨机的噪声控制,专业隔音降噪公司,、以及各类机械动力设备减振降噪噪声治理的公司,同时为客户提供咨询与解决方案 | 乌鲁木齐万通汽车学校| 污泥处理设备|污泥固化固液分离压泥机压滤机厂家-山东冠诚开山贸易 | 慢直播摄像头厂家,监控直播摄像机厂家,景区慢直播设备,rtmp推流直播摄像头,实时摄像头监控直播-监控慢直播厂家:专注监控慢直播系统解决方案 | 轮式挖掘机厂家_抓铁机_全自动混凝土搅拌车_山重机械【官网】 | 卧螺离心机-固液分离机-台州春鼎机械制造有限公司 | 乐云SEO | 品牌营销:抖音小红书关键词优化-ai搜索优化GEO推广 | 联系我们果博福布斯公司客服电话17787888880[河南河北区] | 深圳中安视讯科技发展有限公司 - 深圳中安视讯科技发展有限公司 深圳展厅设计_产业园区展馆设计_展馆设计公司_健康产业展馆设计_展厅设计哪家好_华竣国际 | 伸缩机厂家-现货快递物流伸缩皮带机|装车输送机-乐清市华森自动化设备有限公司 | 抛丸机-通过式抛丸机-履带吊钩式抛丸机厂家-青岛泓霖智能设备公司 | 中捷摇臂钻,数控钻床,沈阳中捷设备机床厂官网_沈阳中捷数控摇臂钻床厂 | 信管飞软件官网 - 亚拓软件旗下精细化管理软件、进销存管理软件、混凝土ERP、通风设备ERP、风管报价软件、出纳软件、送货单打印软件、ERP软件等免费下载 | 三机一体除湿干燥机,色母机,称重式拌料机,工业冻水机,中央集中供料-东莞市瑞达机械科技有限公司(瑞达国际) | 苏州洁仪净化科技有限公司 | 济南手板_山东快速成型-山东嘉瑞杰机械科技有限公司 | 湖州搬家公司_档案搬迁_货物运输_钟点搬运价格「湖州蓝天家政综合服务有限公司」 | 整体滤板模板-S型塑料滤砖-MBBR生物悬浮球填料-微孔曝气器-大恒环保科技 | 雷达液位计_耐磨热电偶_蒸汽_柴油,汽油_天然气流量计_巴歇尔槽_一体化温度变送器-江苏翔腾仪表有限公司 | 全自动码垛机|码垛机器人|高位码垛机械手|拆垛机|缠绕机|山东腾阳智能装备有限公司 | 铝基板_铜基板_铝基板厂家诚之益电路—汽车灯铜基板行业制商 | 烘焙服定做_定做烘焙制服_工服定制厂家_烘焙服生产厂家-庆洋制衣 | 银泰洁净--净化工程总承包,20年精耕细作,专为净化而来_银泰洁净--净化工程总承包,20年精耕细作,专为净化而来 | 河南反渗透设备,河南纯净水设备,河南软化水设备,郑州EDI超纯水设备,郑州水处理设备厂家_河南江宇环保科技有限公司 | 山东万通液压股份有限公司-自卸车专用油缸,能源采掘设备油缸,机械装备用油缸,油气弹簧,工程机械油缸,液压元件 | 山东鑫佳日化_洗衣粉生产厂家,从事洗衣粉加工出口 | 木材粉碎机,树枝粉碎机,木材破碎机厂家 | 无人叉车|智能无人叉车|智能AGV叉车|激光叉车AGV厂家_江西丹巴赫机器人股份有限公司 | 气动球阀,电动蝶阀,调节阀,衬氟阀门,水利控制阀,大口径阀门生产厂家-上海百钢阀门集团有限公司-官网,上海阀门品牌 | 制冷加热循环机,密闭高低温一体机,优质密闭低温冷冻机-无锡冠亚恒温制冷技术有限公司 |