ZFYCH_Love

Simply but Powerful

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

 

我们常常会遇到一类具有“容器”特征的对象,他们既是容器,本身也是对象。比如,公司人员管理中的人,他们是处于不同层级,每个层的人下边,又有下属。也就是数的结构。

而在客户端处理这种对象时,如果耦合性考虑的不好,就出现这种情况:

客户端要提前知道对象的结构,判断对象的类型,然后区分枝节点和叶子节点,区别处理。而在处理枝节点时,又要递归处理。

问题:耦合性过强,一旦变更类(而非接口)内部结构,讲引起客户代码的变化;类的实现细节暴漏给了客户端。

解决:将对象组合成树形结构以表示“部分-整体”的层次关系。对客户端来说,他只认接口,无论是来了枝、还是叶,无差别。

将“客户代码与复杂的对象容器结构”解耦是Composite模式的核心思想 

以下是示例代码,均来自于网上。

解耦前的示例代码:

 

 

解耦后的示例代码:

彻底解耦。

不过出现了新的问题,add、remove等方法,对于SingtenBox类没有意义

而接口,因为把这些方法提了上去,也违背了单一职责原则。

这真是需要平衡啊

posted on   xiaoyang_  阅读(301)  评论(1编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示