您的位置:首页 > 游戏 > 游戏 > 商务网站信息审核的重要性在于_外贸站外推广_友情链接英语_腾讯会议付费

商务网站信息审核的重要性在于_外贸站外推广_友情链接英语_腾讯会议付费

2024/12/23 5:18:07 来源:https://blog.csdn.net/2303_76262050/article/details/144311283  浏览:    关键词:商务网站信息审核的重要性在于_外贸站外推广_友情链接英语_腾讯会议付费
商务网站信息审核的重要性在于_外贸站外推广_友情链接英语_腾讯会议付费

背景

展示一个学校院系结构,要在一个页面中展示出学校的院系组成,一个学校有多个学院,一个学院有多个系

传统思路:

学院继承自学校,系继承自学院

问题:

用继承来表示组织大小关系,不便于管理(如在学校类中无法快速管理所有下设学院)

解决方案:

把学校、院、系都看作组织结构,用树形结构进行链接。

基本介绍

组合模式又叫部分整体模式,描述的是部分与整体间的关系。用树形结构来表示部分与整体间的层次关系,属于结构型模式。

三个角色

①Component:一个接口或者是抽象类,对外提供管理子类的方法(如Add,Remove等)

②Leaf:叶子节点,没有子类的最小单元。(被管理者)

③Composite:非叶子节点,用于存储子类,实现Component类中提供的方法。(管理者)

具体实现

角色实现

①Component:新建学校,学院,系类,都继承自Component抽象类。Component抽象类中声明Add()和Remove()方法。在学校,学院,系类中分别实现。

②Leaf:系类在概念上为叶子节点

③Composite:学校,学院在概念上为非叶子节点类。

在代码层面上,学校和学院类通过Component类管理他们的下设类。(在实现Add和Remove中使用的是Component类)。

客户端并不需要关心整体的结构,只需要知道谁包含谁这一层关系。

可拓展性好,在拓展功能时并不需要更改客户端原有的代码。

如果Leaf(叶子节点)与Composite(非叶子节点)差别较大,组合模式并不适用。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com