设计模式 | 适配器模式(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. 概述: 接口的改变,是一个需要程序员们必须(虽然很不情愿)接受和处理的普遍问题.程序提供者们修改他们的代码;系统库被修正;各种程序语言以及相 ...
随机推荐
- UVA - 11175 From D to E and Back(思路)
题目: 思路: 如图E:图中a.b.c.d是有向图D中的顶点,如果ac.bc都指向cd,而ac又指向ce,那bc同样应该有一条指向ce的边不然就不能从图D转换来.所以直接枚举顶点就可以了. 代码: # ...
- Leetcode题目practice
目录 Leetcode题目解答 1. 删除最外层的括号 2. 两数之和 3. 宝石与石头 4. 移除元素 5.删除排序数组中的重复项 6.寻找两个有序数组的中位数 7.盛最多水的容器 8.存在重复元素 ...
- concepts in Turbulent Flow
Table of Contents 1. Concepts/Glossary 1.1. Turbulent eddy viscosity ,μt 1.2. Turbulent kinetic ener ...
- 【模板】51nod 1051 最大子矩阵和
[题解] 二重循环枚举起始列和终止列,竖着往下加,转化为一个最大子段和问题,逐行累加即可. #include<cstdio> #include<cstring> #includ ...
- hdu 1754 I Hate It(线段树水题)
>>点击进入原题测试<< 思路:线段树水题,可以手敲 #include<string> #include<iostream> #include<a ...
- 根据判断数组不为空然后取他的值----数组不会为空---只能判断其size是否大于0
private List<Integer> classId=new ArrayList<Integer>(); business.getClassId()!=null 以上为错 ...
- noip模拟赛 铺瓷砖
[问题描述]有一面很长很长的墙. 你需要在这面墙上贴上两行瓷砖. 你的手头有两种不同尺寸的瓷砖, 你希望用这两种瓷砖各贴一行.瓷砖的长可以用分数表示,贴在第一行的每块瓷砖长度为A/B贴在第二行的每块瓷 ...
- 【BZOJ3790】神奇项链(manacher,树状数组)
题意: 思路:生成一些回文拼起来使生成的段数最小 显然存在一种最优的方案,使生成的那些回文是目标串的极长回文子串 求出对于每个位置的最长回文子串,问题就转化成了: 给定一些已知起始和终止位置的线段,求 ...
- Power of Matrix 等比数列求和 矩阵版!
#include<iostream> #include<cstdio> #include<cmath> #include<cstring> #inclu ...
- [bzoj 1005][HNOI 2008]明明的烦恼(prufer数列+排列组合)
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1005 分析: 首先prufer数列:http://baike.baidu.com/view/1 ...