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; /* ...
随机推荐
- window下TortoiseGit的安装和使用
一.安装git for windows 首先下载git for windows客户端https://git-for-windows.github.io/安装过程没什么特别的,下载完安装包之后,按照提示 ...
- FastAdmin Bootstrap-Table 分页列表 pageList 如何设置?
FastAdmin Bootstrap-Table 分页列表 pageList 如何设置? FastAdmin 的 表格使用的是 Bootstrap-Table 组件,这个组件该有的功能他都有. 默认 ...
- vim中多行注释和多行删除命令
1.多行注释: 1. 首先按esc进入命令行模式下,按下Ctrl + v,进入列(也叫区块)模式; 2. 在行首使用上下键选择需要注释的多行; 3. 按下键盘(大写)“I”键,进入插入 ...
- linux基础(3)
一 正文处理命令及tar命令 使用cat命令进行文件的纵向合并 两种文件的纵向合并方法 : tar命令的功能 : 掌握tar命令的功能:将多个文件(也可能包括目录,因为目录本身也是文件)放在一起存 ...
- Java-Maven-Runoob:Maven 快照(SNAPSHOT)
ylbtech-Java-Maven-Runoob:Maven 快照(SNAPSHOT) 1.返回顶部 1. Maven 快照(SNAPSHOT) 一个大型的软件应用通常包含多个模块,并且通常的场景是 ...
- PL/SQL 训练12--动态sql和绑定变量
--什么是动态SQL?动态PL/SQL--动态SQL是指在运行时刻才构建执行的SQL语句--动态PL/SQL是指整个PL/SQL代码块都是动态构建,然后再编译执行 --动态SQL来可以用来干什么? - ...
- srvctl和crs_start命令无法启动oracle RAC实例, 但sqlplus可以启动
今天遇到一个奇怪问题,发现srvctl和crs_start命令无法启动Oracle RAC实例,但用sqlplus却可以正常启动.最终发现原因是在OCR中数据库的状态变成了disable,将此状态更改 ...
- peerconnection_client分析笔记
Windows版本的peerconnection_client demo是一个win32程序,入口函数为main.cc里面的wWinMain,程序整体流程就从这个入口函数下手开始分析. 1.peer ...
- 预编译头文件来自编译器的早期版本,或者预编译头为 C++ 而在 C 中使用它(或相反)转
vs2010的mfc项目中编译c语言出现错误: "...预编译头文件来自编译器的早期版本,或者预编译头为 C++ 而在 C 中使用它(或相反)" 解决方法: 建工程时 建立空项目 ...
- C99标准新特性的说明
C99标准新特性的说明 一.说明 ====== 这里的讨论的是C语言的国际标准,即国际标准化组织ISO,制定的C语言标准.历史上ISO制定过4个版本的C语言标准,他们分别是:C90(ISO/IEC ...