设计模式 | 适配器模式(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. 概述: 接口的改变,是一个需要程序员们必须(虽然很不情愿)接受和处理的普遍问题.程序提供者们修改他们的代码;系统库被修正;各种程序语言以及相 ...
随机推荐
- Daydreaming Stockbroker(2016 NCPC 贪心)
题目: Gina Reed, the famous stockbroker, is having a slow day at work, and between rounds of solitaire ...
- POJ 3468 线段树区间修改查询(Java,c++实现)
POJ 3468 (Java,c++实现) Java import java.io.*; import java.util.*; public class Main { static int n, m ...
- LA 3029 Subsequence
LA 3029 A sequence of N positive integers (10 < N < 100 000), each of them less than or equal ...
- 九九乘法表-Java
public class Test1 { public static void main(String[] args){ for(int i=1;i<=9;i++){ for(int j=1;j ...
- [luoguP2904] [USACO08MAR]跨河River Crossing(DP)
传送门 f[i] 表示送前 i 头牛过去再回来的最短时间 f[i] = min(f[i], f[j] + sum[i - j] + m) (0 <= j < i) ——代码 #includ ...
- hdu poj KMP简单题目总结
hdu 3336 题意:输入一个字符串求每个前缀在串中出现的次数和 sol:只要稍微理解下next 数组的含义就知道只要把每个有意义的next值得个数加起来即可 PS:网上有dp解法orz,dp[i] ...
- VScode输出中文乱码的解决方法------测试过可以用
用python写个爬虫,配置个VScode环境,发现输出都是乱码,翻阅网站后发现一个简单有效的方法,在此谢过网络上的大牛们的无私分享,我也在此记录一下,以备后用: 文件---->首选项----& ...
- jquery ajax获取json并解析,获取的json是object对象格式
首先我们使用的是ajax方式,推荐一个学习网址: http://blog.csdn.net/shiyaru1314/article/details/51065410 这个博主写的特别好.现在来看我们的 ...
- 【ZJOI2017 Round2练习&BZOJ4827】D1T3 gift(FFT)
题意: 思路:可以看出题目所要最小化的是这样一个形式: 拆出每一项之后发现会变化的项只有sigma a[i]*b[i+t]与c^2,c*(a[i]-b[i]) c可以在外层枚举,剩下的只有sigma ...
- BZOJ(3) 1051: [HAOI2006]受欢迎的牛
1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 7365 Solved: 3937[Submit][Sta ...