当前位置: 首页 > news >正文

[java] 23种设计模式之适配器模式

适配器模式将某个类的接口转换成客户端期望的另一个接口表示,目的是消除由于接口不匹配所造成的类的兼容性问题。主要分为三类:类的适配器模式、对象的适配器模式、接口的适配器模式。首先,我们来看看类的适配器模式

1.1 类的适配器模式

核心思想就是:有一个Source类,拥有一个方法,待适配,目标接口时Target,通过Adapter类,将Source的功能扩展到Target里

public class Source {
 
	public void method1() {
		System.out.println("this is original method!");
	}
}
public class Adapter extends Source implements Target {
 
	@Override
	public void method2() {
		System.out.println("this is the targetable method!");
	}
}

Adapter类继承Source类,实现Target接口,下面是测试类:

public class AdapterTest {
 
	public static void main(String[] args) {
		Target target = new Adapter();
		target.method1();
		target.method2();
	}
}

输出:

this is original method!
this is the targetable method!

这样Target接口的实现类就具有了Source类的功能

1.2 对象的适配器模式

基本思路和类的适配器模式相同,只是将Adapter类作修改,这次不继承Source类,而是持有Source类的实例,以达到解决兼容性的问题

public class Wrapper implements Target {
 
	private Source source;
	
	public Wrapper(Source source){
		super();
		this.source = source;
	}
	@Override
	public void method2() {
		System.out.println("this is the targetable method!");
	}
 
	@Override
	public void method1() {
		source.method1();
	}
}

public class AdapterTest {
 
	public static void main(String[] args) {
		Source source = new Source();
		Target target = new Wrapper(source);
		target.method1();
		target.method2();
	}
}

1.3接口的适配器模式

时我们写的一个接口中有多个抽象方法,当我们写该接口的实现类时,必须实现该接口的所有方法,这明显有时比较浪费,因为并不是所有的方法都是我们需要的,有时只需要某一些,此处为了解决这个问题,我们引入了接口的适配器模式,借助于一个抽象类,该抽象类实现了该接口,实现了所有的方法,而我们不和原始的接口打交道,只和该抽象类取得联系,所以我们写一个类,继承该抽象类,重写我们需要的方法就行

接口:

public interface Sourceable {
	
	public void method1();
	public void method2();
}

抽象类:

public abstract class AbstracterAdapter implements SourceInterface {
    @Override
    public void method1() {
    }

    @Override
    public void method2() {

    }
}

具体类:

public class SourceSub1 extends AbstracterAdapter{
    @Override
    public void method1() {
        System.out.println("the sourceable interface's first Sub1!");
    }
}

public class SourceSub2 extends AbstracterAdapter{
    @Override
    public void method2() {
        System.out.println("the sourceable interface's second Sub2!");
    }
}
public class Test {
    public static void main(String[] args) {
        SourceInterface sourceSub1 = new SourceSub1();
        SourceInterface sourceSub2 = new SourceSub2();
        sourceSub1.method1();
        sourceSub1.method2();
        sourceSub2.method1();
        sourceSub2.method2();
    }
}

测试输出:

the sourceable interface's first Sub1!
the sourceable interface's second Sub2!

达到了我们的效果!

 讲了这么多,总结一下三种适配器模式的应用场景:

类的适配器模式:当希望将一个类转换成满足另一个新接口的类时,可以使用类的适配器模式,创建一个新类,继承原有的类,实现新的接口即可。

对象的适配器模式:当希望将一个对象转换成满足另一个新接口的对象时,可以创建一个Wrapper类,持有原类的一个实例,在Wrapper类的方法中,调用实例的方法就行。

接口的适配器模式:当不希望实现一个接口中所有的方法时,可以创建一个抽象类Wrapper,实现所有方法,我们写别的类的时候,继承抽象类即可。

相关文章:

  • React Developer Tools带你掌握9个React组件调试技巧,十分钟学会
  • docekr 安装 Naocs
  • docker通过dockerfile安装sftp教程。
  • 【学习版】Microsoft Office 2021安装破解教程
  • SpringBoot源码解读与原理分析(三十八)SpringBoot整合WebFlux(一)WebFlux的自动装配
  • AGI概念与实现
  • 二维码门楼牌管理系统技术服务:革新城市标识管理的新篇章
  • C++智能指针
  • 【Fastadmin/ThinkPHP5】使用Queue队列方法详细步骤
  • Leetcode 11. 盛最多水的容器
  • Spring八股 常见面试题
  • IDEA开发环境热部署
  • 用冒泡排序模拟C语言中的内置快排函数qsort!
  • vue项目如何解决金额计算超过15出现精度丢失问题
  • 自然语言处理(NLP)技术
  • 前端按钮动画
  • npm install的-S和-D的区别
  • iOS中卡顿产生的主要原因及优化思路
  • Apache Paimon Append Queue表解析
  • 【语音识别】- 几个主流模型
  • 仅退款正式成历史?仅退款究竟该不该有?
  • 《不眠之夜》上演8年推出特别版,多业态联动形成戏剧经济带
  • 印度加大应对力度,吊销所有巴基斯坦公民签证
  • 著名茶叶专家谢丰镐逝世,享年95岁
  • 国防部:希望美方不要有“受迫害妄想症”,总拿别人当借口
  • 杨靖︱“一笔糊涂账”:博马舍与美国革命