JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(5):责任链模式、观察者模式
一、责任链模式、观察者模式
1、责任链模式:当一个对象在一条链上被多个拦截器处理(烂机器也可以选择不拦截处理它)时,我们把这样的设计模式称为责任链模式,它用于一个对象在多个角色中传递的场景。
2、观察者模式:观察者模式又称为发布电话与模式,是对象的行为模式。观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监视着被观察者的状态,当被观察者的状态变化时,会通知观察者,并让其自动更新自己。
二、责任链模式(例子)
创建测试接口:HelloWorld.java
package com.xfwl.proxy.jdk;
public interface HelloWorld {
public void sayHelloWorld();
}
创建测试接口的实现子类:HelloWorldImpl.java
package com.xfwl.proxy.jdk;
public class HelloWorldImpl implements HelloWorld {
public void sayHelloWorld() {
System.out.println("Hello World!");
}
}
创建代理类:JdkProxyExample.java
package com.xfwl.proxy.jdk; import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
/**
* JDK的动态代理
* @function 两个步骤:(1)建立代理对象和真实服务对象的关系。(2)实现代理逻辑。
* @author 小风微凉
* @time 2018-7-9 上午10:45:53
*/
public class JdkProxyExample implements InvocationHandler {
//真实对象
private Object target=null;
/**
* 建立代理对象和真实对象之间的代理关系,并返回代理对象
* @param target 真实对象
* @return 代理对象
*/
public Object bind(Object target){
this.target=target;
return Proxy.newProxyInstance(
target.getClass().getClassLoader(), //类加载器
target.getClass().getInterfaces(), //动态代理所挂的接口
this //实现方法逻辑的代理类,必须实现InvocationHandler接口的invoke方法
);
}
/**
* 代理方法逻辑
* @param proxy 代理对象
* @param method 当前调度方法
* @param args 当前方法参数
* @return 代理结果返回
* @throws Throwable 异常
*/
public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {
System.out.println("进入代理方法");
System.out.println("在调度真实方法之前的服务");
Object obj=method.invoke(this.target, args);//相当于调用sayHelloWorld方法
System.out.println("在调度真实方法之后的服务");
return obj;
}
}
创建责任链拦截器-1
package com.xfwl.designmodels.responseChain; import java.lang.reflect.Method; import com.xfwl.interceptor.Interceptor;
/**
* 拦截逻辑1
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:03:37
*/
public class Interceptor1 implements Interceptor { @Override
public boolean before(Object proxy, Object target, Method method,
Object[] args) {
System.out.println("【拦截器1】的before方法");
return true;
} @Override
public void around(Object proxy, Object target, Method method, Object[] args) {
// TODO Auto-generated method stub } @Override
public void after(Object proxy, Object target, Method method, Object[] args) {
System.out.println("【拦截器1】的after方法");
}
}
创建责任链拦截器-2
package com.xfwl.designmodels.responseChain; import java.lang.reflect.Method; import com.xfwl.interceptor.Interceptor;
/**
* 拦截逻辑2
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:03:37
*/
public class Interceptor2 implements Interceptor { @Override
public boolean before(Object proxy, Object target, Method method,
Object[] args) {
System.out.println("【拦截器2】的before方法");
return true;
} @Override
public void around(Object proxy, Object target, Method method, Object[] args) {
// TODO Auto-generated method stub } @Override
public void after(Object proxy, Object target, Method method, Object[] args) {
System.out.println("【拦截器2】的after方法");
}
}
创建责任链拦截器-3
package com.xfwl.designmodels.responseChain; import java.lang.reflect.Method; import com.xfwl.interceptor.Interceptor;
/**
* 拦截逻辑3
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:03:37
*/
public class Interceptor3 implements Interceptor { @Override
public boolean before(Object proxy, Object target, Method method,
Object[] args) {
System.out.println("【拦截器3】的before方法");
return true;
} @Override
public void around(Object proxy, Object target, Method method, Object[] args) {
// TODO Auto-generated method stub } @Override
public void after(Object proxy, Object target, Method method, Object[] args) {
System.out.println("【拦截器3】的after方法");
}
}
创建测试类:TestChain.java
package com.xfwl.designmodels.responseChain; import com.xfwl.interceptor.InterceptorJdkProxy;
import com.xfwl.proxy.jdk.HelloWorld;
import com.xfwl.proxy.jdk.HelloWorldImpl; /**
* 测试责任链模式
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:05:43
*/
public class TestChain {
/**
* @param args
*/
public static void main(String[] args) { //拿到代理对象1,并绑定真实对象
HelloWorld proxy1=(HelloWorld) new InterceptorJdkProxy().bind(
new HelloWorldImpl(),
"com.xfwl.designmodels.responseChain.Interceptor1"
);
//拿到代理对象2,并绑定真实对象
HelloWorld proxy2=(HelloWorld) new InterceptorJdkProxy().bind(
proxy1,
"com.xfwl.designmodels.responseChain.Interceptor2"
);
//拿到代理对象3,并绑定真实对象
HelloWorld proxy3=(HelloWorld) new InterceptorJdkProxy().bind(
proxy2,
"com.xfwl.designmodels.responseChain.Interceptor3"
);
//执行代理逻辑
proxy3.sayHelloWorld(); } }
运行结果:
【拦截器3】的before方法
【拦截器2】的before方法
【拦截器1】的before方法
Hello World!
【拦截器1】的after方法
【拦截器2】的after方法
【拦截器3】的after方法
三、观察者模式(例子)
创建一个产品列表类:ProductionList.java
package com.xfwl.designmodels.observer;
import java.util.ArrayList;
import java.util.List;
import java.util.Observable;
import java.util.Observer;
/**
* 创建一个产品列表
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:18:36
*/
public class ProductionList extends Observable {
//产品容器
private List<String> productionList=null;
//单例模式:懒汉式
private static ProductionList instance;
private ProductionList(){}
/**
* 取得唯一实例
* @return 产品列表唯一实例
*/
public static ProductionList getInstance(){
if(instance==null){
instance=new ProductionList();
instance.productionList=new ArrayList<String>();
}
return instance;
}
/**
* 增加观察则(电商接口)
* @param observer 观察者
*/
public void addProductionListObserver(Observer observer){
this.addObserver(observer);
}
/**
* 新增产品
* @param newProudct 新产品
*/
public void addProudct(String newProudct){
this.productionList.add(newProudct);
System.out.println("产品列表新增了产品:"+newProudct);
//告诉观察者,当前被观察者发生了变化
this.setChanged();
//通知观察者,开始相关操作
this.notifyObservers(newProudct);
}
}
创建一个京东电商推送接口类:JingDongObserver.java
package com.xfwl.designmodels.observer; import java.util.Observable;
import java.util.Observer;
/**
* 京东电商接口
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:29:03
*/
public class JingDongObserver implements Observer { @Override
public void update(Observable o, Object product) {
String newProudct=(String)product;
System.out.println("发送新产品【"+newProudct+"】同步到京东商城");
}
}
创建一个淘宝电商推送接口类:TaoBaoObserver.java
package com.xfwl.designmodels.observer; import java.util.Observable;
import java.util.Observer;
/**
* 淘宝电商接口
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:29:03
*/
public class TaoBaoObserver implements Observer { @Override
public void update(Observable o, Object product) {
String newProudct=(String)product;
System.out.println("发送新产品【"+newProudct+"】同步到淘宝商城");
}
}
创建一个测试类:TestObserver.java
package com.xfwl.designmodels.observer;
/**
* 观察者模式测试
* @function
* @author 小风微凉
* @time 2018-7-9 下午4:32:12
*/
public class TestObserver {
/**
* @param args
*/
public static void main(String[] args) {
ProductionList observable=ProductionList.getInstance();
TaoBaoObserver taobao=new TaoBaoObserver();
JingDongObserver jingdong=new JingDongObserver();
observable.addObserver(jingdong);
observable.addObserver(taobao);
observable.addProudct("德芙·巧克力");
}
}
测试结果:
产品列表新增了产品:德芙·巧克力
发送新产品【德芙·巧克力】同步到淘宝商城
发送新产品【德芙·巧克力】同步到京东商城
JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(5):责任链模式、观察者模式的更多相关文章
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(2):SSM+Redis概念理解
一.SSM+Redis的结构图 在Java互联网中,以Spring+SpringMVC+MyBatis(SSM)作为主流框架,SSM+Redis的结构图如下: 二.下面介绍它们各自承担的功能: 1.S ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(1):Mybatis和Hibernate概念理解
一.关键字说明: oop:面向对象 aop:面向切面 ioc:控制反转 orm:对象关系映射 pojo:数据库表映射的java实体类 二.常识说明:1.hibernate和mybatis都属于持久层. ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(12):XML配置自动扫描包,自动加载*.properties文件
一.XML和注解组合使用 前几篇的测试案例都是在Java类中配置,现在换一种使用方式,在XML中配置,使Spring IoC容器在启动之后自动去扫描配置的包路径,扫描加载指定路径下的propertie ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(10):通过注解(annotation)装配Bean之(@Configguration、@Component、@Value、@ComponentScan、@Autowired、@Primary、@Qualifier、@Bean)
一.通过注解(annotation)装配Bean 通过之前的学习,我们已经知道如何使用XML装配Bean,但是更多的时候已经不再推荐使用XML的方式去装配Bean,更多的时候会考虑注解(annotat ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(8):装配SpringBean概述(如何合理使用装配级别)
一. 装配Bean概述 关于如何将自己开发的Bean配置到Spring IoC容器中,大部分场景下,我们都会使用ApplicationContext的具体实现类,因为对应的Spring IoC容器功 ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(7):装配SpringBean·依赖注入装配
一.依赖注入的三种方式 在实际环境中实现IoC容器的方式主要分为两大类,一类是依赖查找,依赖查找是通过资源定位,把对应的资源查找回来.另一类则是依赖注入.一般而言,依赖注入可分为3中方式: ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(6):Spring IOC容器学习(概念、作用、Bean生命周期)
一.IOC控制反转概念 控制反转(IOC)是一种通过描述(在Java中可以是XML或者是注解)并通过第三方去生产或获取特定对象的方式. 主动创建模式,责任在于开发者,而在被动模式下,责任归于Ioc容器 ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(11):XML和Annotation装配Bean的混合使用(@ImportResource)
一.XML和Annotation装配Bean如何合理使用 引入第三方资源包中类的时候,建议使用XML配置,而使用自己编写的Java类的时候,推荐使用Annotation注解配置Bean. 二.关于注解 ...
- JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(9):通过XML装配Bean
一.通过XML装配Bean 装配简易值 装配集合 命名空间装配(暂不测试) 二.测试例子 创建一个用户类:UserBean.java package com.xfwl.spring.assem; /* ...
随机推荐
- Tensorflow的采样方法:candidate sampling(zhuan)
zhuanzi:https://blog.csdn.net/u010223750/article/details/69948463 采样介绍 假如我们有一个多分类任务或者多标签分类任务,给定训练集(x ...
- Mysql ERROR 1032 (HY000): Can't find record in TABLE
最近用Mysql出现一个很奇怪的问题. 用SELECT * FROM `v_vod` ORDER BY vod_addtime desc LIMIT 0,18查询得到1个错误 ERROR 1032 ( ...
- bzoj 3998 [TJOI2015]弦论——后缀自动机
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3998 相同子串算多个的话,先求好 right ,然后求一个 sm 表示走到这个点之后有几种走 ...
- Oracle记录(三) Scott用户的表结构
在Oracle的学习之中,重点使用的是SQL语句,而所有的SQL语句都要在scott用户下完成,这个用户下一共有四张表,可以使用: SELECT * FROM tab; 查看所有的数据表的名称,如果现 ...
- EXCEL类型库的添加
1. 创建新的C++工程 创建基于对话框的MFC程序 2. 添加库.添加Excel类库 在工程名上右键,选择“添加”—“类”(或者点击菜单栏的“项目”->“添加类”),选择“TypeLib中的M ...
- HDOJ5877(dfs序+离散化+树状数组)
Weak Pair Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- 实例甜点 Unreal Engine 4迷你教程(3)之用C++改变Image小部件的其它属性
完成本迷你教程之前,请前往完成以下迷你教程: ·实例甜点 Unreal Engine 4迷你教程(2)之用C++改变Image小部件的颜色: 在上一次的迷你教程的LearnWidgets工程上进行(如 ...
- 阿里云openapi接口使用,PHP,视频直播
1.下载sdk放入项目文件夹中 核心就是aliyun-php-sdk-core,它的配置文件会自动加载相应的类 2.引入文件 include_once LIB_PATH . 'ORG/aliyun-o ...
- mysql特性及部署规范
--分支版本,mysql对cpu,内存,io子系统资源利用特点--oracle mysql,mariadb,percona server--部署规范建议,系统安装,mysql安装,其他规范互联网业务为 ...
- 升级python到2.7
wget http://python.org/ftp/python/2.7.8/Python-2.7.8.tgz tar zxvf Python-.tgz cd Python- ./configure ...