设计模式 | 适配器模式(adapter)
定义:
结构:(书中图,侵删)
实例:
package designpattern.adapter; import java.util.HashSet;
import java.util.Set; public class ForeignIdentify {
String socailSecurityNumber; // 模拟一个社保号的数据库
static Set<String> dbSet = new HashSet<>();
static {
dbSet.add("F001");
dbSet.add("F002");
dbSet.add("F003");
} public boolean check(String socailSecurityNumber) {
if (dbSet.contains(socailSecurityNumber)) {
System.out.println(socailSecurityNumber + "是外国的合法公民");
return true;
} else {
System.out.println(socailSecurityNumber + "不是外国的合法公民");
return false;
} }
}
package designpattern.adapter; import java.util.HashSet;
import java.util.Set; public class ChineseIdentify {
String idCardNumber; // 模拟一个身份证号的数据库
static Set<String> dbSet = new HashSet<>();
static {
dbSet.add("张三C001");
dbSet.add("李四C002");
dbSet.add("王五C003");
} public boolean check(String idCardNumber, String name) {
if (dbSet.contains(name + idCardNumber)) {
System.out.println(name + idCardNumber + "是中国的合法公民");
return true;
} else {
System.out.println(name + idCardNumber + "不是中国的合法公民");
return false;
} }
}
package designpattern.adapter; import java.util.HashMap;
import java.util.Map; public class ChinesePassport extends ForeignIdentify {
ChineseIdentify chineseIdentify = new ChineseIdentify(); // 模拟身份证、名字对应数据库
static Map<String, String> db = new HashMap<>();
static {
db.put("C001", "张三");
db.put("C002", "李四");
db.put("C003", "王五"); } @Override
public boolean check(String idCardNumber) {
// 为了模拟两个接口不完全一样,假设中国的身份验证需要身份证号和名字两个条件
return chineseIdentify.check(idCardNumber, getName(idCardNumber));
} private String getName(String idCardNumber) {
return db.get(idCardNumber);
}
}
package designpattern.adapter;
public class Client {
public static void main(String[] args) {
ForeignIdentify foreignIdentify = new ForeignIdentify();
enter("F001", foreignIdentify);
enter("F004", foreignIdentify);
// 直接用身份证号来验证
enter("C003", foreignIdentify);
// 换成护照
foreignIdentify = new ChinesePassport();
enter("C003", foreignIdentify);
}
public static void enter(String number, ForeignIdentify foreignIdentify) {
System.out.println("=============外国入关==============");
if (foreignIdentify.check(number)) {
System.out.println("允许入关!");
} else {
System.out.println("禁止入关!");
}
}
}
结果输出:
=============外国入关==============
F001是外国的合法公民
允许入关!
=============外国入关==============
F004不是外国的合法公民
禁止入关!
=============外国入关==============
C003不是外国的合法公民
禁止入关!
=============外国入关==============
王五C003是中国的合法公民
允许入关!
总结:
设计模式 | 适配器模式(adapter)的更多相关文章
- 设计模式 - 适配器模式(adapter pattern) 具体解释
适配器模式(adapter pattern) 详细解释 本文地址: http://blog.csdn.net/caroline_wendy 适配器模式(adapter pattern): 将一个类的接 ...
- 设计模式 - 适配器模式(adapter pattern) 枚举器和迭代器 具体解释
适配器模式(adapter pattern) 枚举器和迭代器 具体解释 本文地址: http://blog.csdn.net/caroline_wendy 參考适配器模式(adapter patter ...
- 设计模式--适配器模式Adapter(结构型)
一.适配器模式 适配器模式的主要作用是在新接口和老接口之间进行适配.将一个类的接口转换成客户端期望的另外一个接口.其实适配器模式有点无赖之举,在前期设计的时候,我们就不应该考虑适配器模式,而应该通过重 ...
- 说说设计模式~适配器模式(Adapter)
返回目录 之前和大家一起谈了工厂模式和单例模式,今天来看一下另一种非常常用的模式,它就是适配器模式,第一次看到这个模式是通过“张逸”老师的“设计之道”这篇文章,在这里表adapter讲的很透彻,今天把 ...
- [工作中的设计模式]适配器模式adapter
一.模式解析 适配器模式把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作. 也就是说,如果已经写好了一个接口,但是又来了一种截然不同的接口,如 ...
- C#设计模式——适配器模式(Adapter Pattern)
一.概述在软件开发中,常常会想要复用一个已经存在的组件,但该组件的接口却与我们的需要不相符,这时我们可以创建一个适配器,在需复用的组件的接口和我们需要的接口间进行转换,从而能够正常的使用需复用的组件. ...
- 设计模式-适配器模式(Adapter)
简介: 适配器模式在我看来是最无聊的一种模式,因为他根本不是一种新的创意模式,而是一种不得已而为之的模式.就算不学适配器模式,在具体应用场景中也会自然而然的想到这种解决方案. 张三在英国留学时买了个笔 ...
- 大话设计模式--适配器模式 Adapter -- C++实现实例
1.适配器模式: 将一个类的接口转换为客户希望的另一个接口,使得原来由于接口不能一起工作的那些类一起工作. 适配器模式一般用于希望复用一些现存的类,但是接口又与复用环境要求不一致的情况. 适配器模式分 ...
- [设计模式]适配器模式Adapter
将一个类的接口转换成客户希望的另外一个接口. A d a p t e r模式使得原本 由于接口不兼容而不能一起工作的那些类可以一起工作.
- 设计模式(五)适配器模式Adapter(结构型)
设计模式(五)适配器模式Adapter(结构型) 1. 概述: 接口的改变,是一个需要程序员们必须(虽然很不情愿)接受和处理的普遍问题.程序提供者们修改他们的代码;系统库被修正;各种程序语言以及相 ...
随机推荐
- python_ 学习笔记(hello world)
python中的循环语句 循环语句均可以尾随一个else语句块,该块再条件为false后执行一次 如果使用break跳出则不执行. for it in [1,2,3,4]: print(it,end= ...
- buf.writeFloatBE()函数详解
buf.writeFloatBE(value, offset[, noAssert]) buf.writeFloatLE(value, offset[, noAssert]) value {Numbe ...
- 【模板】51nod 1051 最大子矩阵和
[题解] 二重循环枚举起始列和终止列,竖着往下加,转化为一个最大子段和问题,逐行累加即可. #include<cstdio> #include<cstring> #includ ...
- POJ 1655 Balancing Act && POJ 3107 Godfather
题目大意: 根据题目的图很好理解意思,就是记录每一个点的balance,例如 i 的balance就是把 i 从这棵树中除去后得到的森林中含有结点数最多 的子树中的节点个数,然后找到所有节点中对应的b ...
- codevs4343 找回密码
题目描述 Description jrMz 很喜欢动漫<叛逆的鲁鲁修>(额= =不知道是不是因为他盯上了动画片里的 MM),他准备以一种神奇的方式降临<叛逆的鲁鲁修>世界,所以 ...
- Hihocoder 1325 (splay)
Problem 平衡树 Treap 题目大意 维护一个数列,支持两种操作. 操作1:添加一个数x. 操作2:询问不超过x的最大的数. 解题分析 尝试了一下用指针来写splay,感觉写起来还是比较流畅的 ...
- 在DJANGO中如何定义get_absolute_url
有好几种办法呢... 书上有说: 常见的: class Image(models.Model): user = models.ForeignKey(settings.AUTH_USER_MODEL, ...
- [转]C++回调函数(callback)的使用
原文地址:http://blog.sina.com.cn/s/blog_6568e7880100p77y.html 什么是回调函数(callback) 模块A有一个函数foo,他向模块B传递fo ...
- java 中public 类
java 中的文件名是以这个文件里面的public 的那个类命名的(也就是说文件名和这个文件里面的那个public 属性的class 名称一样), 同一个文件中不能放多个(超过2个)的pulic 类. ...
- Intellij IDEA安装插件
从Eclipse到Intellij IDEA换过来,还是没有适应,并且电脑异常的卡顿,4核4G内存的机器表示伤不起.Intellij IDEA还有待我进行调教. 今天说明一下怎样安装插件.以keyPr ...