设计模式--适配器模式(JDK中的应用)

适配器模式将不兼容的接口转换为客户期望的接口,使得原本无法一起工作的类可以协同工作。本文详细介绍了适配器模式的定义、UML图、类和对象适配器模式的区别,以及其在JDK中的应用,如ArrayList和LinkedList的适配。适配器模式的优点在于提高代码复用性和扩展性,但过度使用可能导致系统混乱。缺省适配器模式则允许子类只实现所需的部分接口方法。
摘要由CSDN通过智能技术生成

本来想开始进行java集合框架的学习,但是看到集合框架中用到了适配器模式,所以先学习一下此设计模式,能让我们对java集合框架的设计思想理解更深入。JDK源码中应用了很多设计模式,在学习源码的遇到的时候会一一进行学习。闲言少叙,开始适配器模式。

适配器模式定义

适配器模式定义是:适配器模式把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作。其别名为包装器(Wrapper)。 解释适配器很多教材和博客都采用电源适配器这个例子:比如中国和美国的电源插座不匹配,怎么给手机充电呢,这就需要一个适配器,来进行适配。
适配器模式既可以作为类结构型模式,也可以作为对象结构型模式。 结构型模式(Structural Pattern)描述如何将类或者对 象结合在一起形成更大的结构,就像搭积木,可以通过简单积木的组合形成复杂的、功能更为强大的结构。结构型模式可以分为类结构型模式和对象结构型模式:1. 类结构型模式关心类的组合,由多个类可以组合成一个更大的系统,在类结构型模式中一般只存在继承关系和实现关系。 2. 对象结构型模式关心类与对象的组合,通过关联关系使得在一 个类中定义另一个类的实例对象,然后通过该对象调用其方法。 根据“合成复用原则”,在系统中尽量使用关联关系来替代继承关系(多用组合少用继承),因此大部分结构型模式都是对象结构型模式。

这时候我们可以引出一个原则:对类的功能的扩展,要多用组合,少用继承。对于类的扩展,在面向对象的编程过程中,我们首先想到的是类的继承,由子类继承父类,从而完成了对子类功能的扩展。但是,面向对象的原则告诉我们,对类的功能的扩展要多用组合,而少用继承。详细的介绍可以查看这篇博客:组合还是继承,这是一个问题。此博客举的例子很好,易于理解组合相对于继承的优点。

适配器模式的UML图

画出设计模式对于的uml图是学习设计模式的基本要求,面试中也会让我们画出设计模式的uml图,进行解释。
模式所涉及的角色有:
  ● 目标(Target)角色:这就是所期待得到的接口。注意:由于类适配器模式,因此目标需是接口。
  ● 源(Adapee)角色:现在需要适配的接口。
  ● 适配器(Adaper)角色:适配器类是本模式的核心。适配器把源接口转换成目标接口。显然,这一角色不可以是接口,而必须是具体类。

类适配器模式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值