Java设计模式(适配器模式)

定义

       将一个类的接口转换成客户希望的另一个接口。适配器模式让那些接口不兼容的类可以一起工作。

角色

       目标抽象类(Target):目标抽象类定义客户所需的接口(在类适配器中,目标抽象类只能是接口)。

       适配器类(Adapter):它可以调用另一个接口,做为转换器对Adaptee和Target进行适配。

       适配者类( Adaptee ):即被适配的角色,通常是客户希望使用但又无法直接调用的业务方法。

优点

       将目标类和适配者类解耦,通过引入一个适配器类来重用现有的适配者类,无须修改原有结构

       增加了类的透明性和复用性,提高了适配者的复用性,同一个适配者类可以在多个不同的系统中复用 灵活性和扩展性非常好

       类适配器模式:置换一些适配者的方法很方便

       对象适配器模式:可以把多个不同的适配者适配到同一个目标,还可以适配一个适配者的子类

缺点

       类适配器模式:    

              (1) 一次最多只能适配一个适配者类,不能同时适配多个适配者;    

              (2) 适配者类不能为最终类;    

              (3) 目标抽象类只能为接口,不能为类  

               (4) 使用继承耦合性过强,被适配方法发生变化则会导致适配器也要做相应修改

       对象适配器模式:    

              在适配器中置换适配者类的部分方法比较麻烦

适用场景

       系统需要使用一些现有的类,而这些类的接口不符合系统的需要,甚至没有这些类的源代码

       创建一个可以重复使用的类,用于和一些彼此之间没有太大关联的类,包括一些可能在将来引进的类一起工作

案例

       在为某学校开发教务管理系统时,开发人员发现需要对学生成绩进行排序和查找,该系统的设计人员已经开发了一个成绩操作接口ScoreOperation,在该接口中声明了排序方法Sort(int[]) 和查找方法Search(int[], int),为了提高排序和查找的效率,开发人员决定重用现有算法库中的快速排序算法类QuickSortClass和二分查找算法类BinarySearchClass,其中QuickSortClass的QuickSort(int[])方法实现了快速排序,BinarySearchClass的BinarySearch (int[], int)方法实现了二分查找。

       由于某些原因,开发人员已经找不到该算法库的源代码,无法直接通过复制和粘贴操作来重用其中的代码;而且部分开发人员已经针对ScoreOperation接口(自己开发的接口)编程,如果再要求对该接口进行修改或要求大家直接使用QuickSortClass类和BinarySearchClass类将导致大量代码需要修改。

       现使用适配器模式设计一个系统,在不修改已有代码的前提下将类QuickSortClass和类BinarySearchClass的相关方法适配到ScoreOperation接口中。

       根据以上要求完成教务系统学生成绩排序查找程序的结构图建模,使用JAVA或C#语言编写控制台应用程序,并能调试运行。

类图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值