位置: IT常识 - 正文

设计模式---适配器模式(设计模式适配器模式代码编写)

编辑:rootadmin
简述 类型:结构型 目的:解决接口不兼容问题。 话不多说,看个案例吧。 优化案例 最初版v0 在真实的开发场景中,系统的每个模块都是分配给不同的团队或个人来开发的。这使得事前沟通变得尤为重要,且沟通问题也时有发生。现在公司有两个模块无法兼容,难道只能重写其中的一个吗? class User { St ... 简述类型:结构型目的:解决接口不兼容问题。

推荐整理分享设计模式---适配器模式(设计模式适配器模式代码编写),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:适配者设计模式,设计模式适配器模式,设计模式适配器模式实验报告,设计模式适配器模式和装饰器模式有什么区别,设计模式适配器属于什么类型,设计模式适配器模式和装饰器模式有什么区别,设计模式适配器与目标完全解,设计模式适配器模式,内容如对您有帮助,希望把文章链接给更多的朋友!

话不多说,看个案例吧。

优化案例最初版v0

在真实的开发场景中,系统的每个模块都是分配给不同的团队或个人来开发的。这使得事前沟通变得尤为重要,且沟通问题也时有发生。现在公司有两个模块无法兼容,难道只能重写其中的一个吗?

class User { String name; String sex; int age; // 剩下的属性就不写了,都是废话没啥意义 public User(String name, String sex, int age) { this.name = name; this.sex = sex; this.age = age; }}interface Filter { List<User> findAll(); User findByName(String name);}class FilterImpl implements Filter { // Adaptee List<User> users; public FilterImpl(List<User> users) { this.users = users; } public List<User> findAll() { return users; } public User findByName(String name) { if (name == null) throw new RuntimeException("请输入正确的ID!"); return (User) users.stream().filter(t -> name.equals(t.name)).findFirst().orElse(null); }}interface JsonFilter { // Target String allToJson(); String findByNameToJson(String id);}

客户想要查询user并且返回结果对象的Json,只是当前的两个模块没法满足需求,如果不想修改这两个模块,我们如何实现两个模块功能的整合呢?

修改版v1(类适配器)设计模式---适配器模式(设计模式适配器模式代码编写)

我们引入一个新的类作为适配器来适配原有的两个模块。

class User { String name; String sex; int age; // 剩下的属性就不写了,都是废话没啥意义 public User(String name, String sex, int age) { this.name = name; this.sex = sex; this.age = age; }}interface Filter { List<User> findAll(); User findByName(String name);}class FilterImpl implements Filter { // Adaptee List<User> users; public FilterImpl(List<User> users) { this.users = users; } public List<User> findAll() { return users; } public User findByName(String name) { if (name == null) throw new RuntimeException("请输入正确的ID!"); return (User) users.stream().filter(t -> name.equals(t.name)).findFirst().orElse(null); }}interface JsonFilter { // Target String allToJson(); String findByNameToJson(String id);}class JsonFilterAdapter extends FilterImpl implements JsonFilter { // Adapter public JsonFilterAdapter(List<User> users) { super(users); } public String allToJson() { List<User> users = super.findAll(); return new Gson().toJson(users); } public String findByNameToJson(String name) { User user = super.findByName(name); return new Gson().toJson(user); }}

代码修改后,我们来看一个客户端的使用案例。

class client {public static void main(String[] args) { List<User> users = new ArrayList<>(); users.add(new User("张三", "男", 19)); users.add(new User("李四", "男", 35)); users.add(new User("小红", "女", 21)); JsonFilterAdapter jfa = new JsonFilterAdapter(users); String allUser = jfa.allToJson(); String user = jfa.findByNameToJson("张三"); System.out.printf("%s%n%s", allUser, user); }}

使用了类适配器确实让我们可以在不修改原有两个模块的情况下,以增加一个适配器类为代价整合两大模块。但,由于类适配器需要继承结构中的Adaptee,且在客户端中的使用我们也能看出虽然我们能够调用继承的方法但没有直接使用。既然不使用为啥继承呢?

这就引出了新的问题:我们是否有必要使用继承来实现适配器。如答案是否,那不使用继承我们又如何设计适配器呢。这就得看接下来的优化了。

修改版v2(对象适配器)(推荐)

我们的问题,对象适配器可以解决!!!

class User { String name; String sex; int age; // 剩下的属性就不写了,都是废话没啥意义 public User(String name, String sex, int age) { this.name = name; this.sex = sex; this.age = age; }}interface Filter { List<User> findAll(); User findByName(String name);}class FilterImpl implements Filter { // Adaptee List<User> users; public FilterImpl(List<User> users) { this.users = users; } public List<User> findAll() { return users; } public User findByName(String name) { if (name == null) throw new RuntimeException("请输入正确的ID!"); return (User) users.stream().filter(t -> name.equals(t.name)).findFirst().orElse(null); }}interface JsonFilter { // Target String allToJson(); String findByNameToJson(String id);}class JsonFilterAdapter implements JsonFilter { // 不在继承FilterImpl private Filter filter; // 继承 → 聚合 public JsonFilterAdapter(List<User> users) { this.filter = new FilterImpl(users); } public String allToJson() { List<User> users = filter.findAll(); return new Gson().toJson(users); } public String findByNameToJson(String name) { User user = filter.findByName(name); return new Gson().toJson(user); }}

我们再看看客户端的调用代码。

class client {public static void main(String[] args) { List<User> users = new ArrayList<>(); users.add(new User("张三", "男", 19)); users.add(new User("李四", "男", 35)); users.add(new User("小红", "女", 21)); JsonFilterAdapter jfa = new JsonFilterAdapter(users); String allUser = jfa.allToJson(); String user = jfa.findByNameToJson("张三"); System.out.printf("%s%n%s", allUser, user); }}

调用代码完全没有变化,但实际上已经无法在客户端中调用Filter中定义的方法了,这使得Adapter类的都耦合度更低,有利于使用和维护。

总结优点使用适配器模式,不需要对于现有模块修改,符合开闭原则。可以针对现有的模块创建多种多样的适配器,而客户端只需要调用适配器即可。让客户端与现有的多个模块解耦,防止日后模块修改时客户端也需要随之修改。缺点随着适配器类的加入,现有的系统将越发复杂。增加了开发人员对于系统的理解难度。适用场景需要整合两个不兼容接口的场景。
本文链接地址:https://www.jiuchutong.com/zhishi/310485.html 转载请保留说明!

上一篇:总结帝国CMS下在PHP文件中调用数据库类执行SQL语句实例(帝国cms专题)

下一篇:mysql数据库有什么特点(MySQL数据库有什么特点)

  • QQ如何显示火花(qq怎么显示火花图标)

  • 固态硬盘分区好不好(固态硬盘分区好还是不分区好)

  • 电脑没有word文档怎么办(电脑没有word文档怎么打开文件)

  • 怎么@群里没说话的人(怎么@群里的一个人没有发过短信的人)

  • vivo手机闪充失效(vivo手机闪充突然不闪充了怎么回事)

  • 快手直播收到的礼物为什么不显示(快手直播收到的黄钻是啥意思)

  • 平板自动跳屏怎么回事(平板屏幕自动跳转)

  • 苹果耳机怎么看电量是否充满(苹果耳机怎么看电池还有多少电量)

  • iwatch5不能删微信聊天(新版watch5微信删除不了)

  • .epub是什么文件(epub是什么文件格式可以打印吗)

  • 苹果已激活和未激活的区别(苹果已激活未注册怎么办)

  • 荣耀v30pro不能用有线耳机吗(荣耀v30pro不能连wifi了)

  • 华为快充线和普通线的区别(华为快充线和普通线哪个好)

  • ar功能是什么意思(ar啥意思)

  • opporeno死机怎么办(oppo死机咋办)

  • 硬盘接sata2还是sata3(硬盘线接sata几)

  • iphone电池健康掉的快(iPhone电池健康掉到80以下)

  • 6splus尺寸长宽多少(6s plus尺寸是多少)

  • 充电器分几种(充电器分几种类型)

  • 芒果tv学生认证怎么弄(芒果tv学生认证有什么限制)

  • 为什么微信备注后面会有一个耳朵(为什么微信备注突然没了)

  • 双十一活动是多少天(双十一活动多少淘气值)

  • vivoz5x能视频美颜吗(vivo5手机视频怎么开美颜)

  • iphone7能升级ios13吗(iphone7能升级ios14吗)

  • 手机一直正在搜索怎么回事(手机一直正在搜索网络怎么办)

  • 如何使用键盘关电脑(如何使用键盘关闭所有运行)

  • 微信步数跟主页不一样(微信步数跟主页有关系吗)

  • 十进制小数转十六进制(十进制小数转十二进制)

  • paytime.exe - paytime是什么进程 有什么用

  • Element-Plus el-col、el-row快速布局

  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设 电脑维修 湖南楚通运网络