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; /* ...
随机推荐
- gen already exists but is not a source folder
遇到android项目导入出现后重复空包等错误,往往是导入的java编译级别有关,点击项目properties-> java Compiler ->修改Compiler complianc ...
- nextSibling VS nextElementSibling
2. nextSibling vs nextElementSibling { //FF { 在Firefox中,link2的nextSibling并不是link3,因为两者之间有一个换行符. 这被认为 ...
- jave获取音频时长
本文转载自:http://blog.csdn.net/ntotl/article/details/50419983 下载 jave-1.0.2.jar File source =new File('d ...
- python使用multiprocessing进行多进程编程(1)
multiprocessing模块实现了对多进程编程的封装,让我们可以非常方便的使用多进程进行编程.它的使用方法非常类似threading模块. 1.创建一个进程 import multiproces ...
- 【原】Coursera—Andrew Ng机器学习—Week 4 习题—Neural Networks 神经网络
[1] Answer:C [2] Answer:D 第二层要输出四个元素a1 a2 a3 a4.输入x有两个,加一个x0是三个.所以是4 * 3 [3] Answer:C [4] Answer:C [ ...
- Game Develop Books
[Working On] [Pending] 3.<实时计算机图形学> 4.<游戏编程精粹1> 5.<游戏编程精粹2> 6.<3D游戏引擎设计:实时计算机图形 ...
- SQL SERVER 微软下载地址
https://www.microsoft.com/zh-cn/search/DownloadsDrillInResults.aspx?q=sql+server+2012&cateorder= ...
- 【原创】4. MYSQL++ 之 SQLTypeAdapter类型、SQLQueryParms类型 与 SQLBuffer
1. mysqlpp::SQLBuffer 该类型其实就是SQLTypeAdapter传入的各种类型(int, string, double, long, String, …) 的包装,包装的结果就是 ...
- json_encode和json_decode和isset和array_key_exists
1.json_decode() json_decode — 对 JSON 格式的字符串进行编码 说明 mixed json_decode ( string $json [, bool ...
- 04.webservice客户端调用
不要求所有的元素都理解,真正做开发的时候,有一些必须是要用的. 以后我们做开发的时候服务访问点的集合就一个服务的访问点.服务访问点绑定了具体的一个服务类,绑定的这个东西它本身也是一个元素.往上找,四个 ...