使用JDK动态代理完成自定义连接池

上传人:ss****gk 文档编号:236130909 上传时间:2022-01-06 格式:DOC 页数:5 大小:152KB
返回 下载 相关 举报
使用JDK动态代理完成自定义连接池_第1页
第1页 / 共5页
使用JDK动态代理完成自定义连接池_第2页
第2页 / 共5页
使用JDK动态代理完成自定义连接池_第3页
第3页 / 共5页
使用JDK动态代理完成自定义连接池_第4页
第4页 / 共5页
使用JDK动态代理完成自定义连接池_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《使用JDK动态代理完成自定义连接池》由会员分享,可在线阅读,更多相关《使用JDK动态代理完成自定义连接池(5页珍藏版)》请在金锄头文库上搜索。

1、JDK动态代理1什么是JDK动态代理刚刚写ItcastConnection时爽么?因为Connection中的方法太多了,每个都要写,所以 很累吧。累点到是没什么,可以完成功能就是好的。但是不是什么时候可以用代理的,有时 你可能会遇到要代理的东西,只有在运行时才能知道,所以你不可能先把代理写出来!这时 就需要使用动态代理。JDK动态代理是JavaSE中一个高级特性,不是那么好理解的,但是它可是框架们的“秘 密武器”。你要是可以理解它,那么将来在学习框架时,你就会知道框架是怎么完成一些“神 奇功能”的。动态代理的作用:在运行时生成一个实现了指定接口的对象。例如在运行吋生成一个对象,这个对象实现了

2、 Connection接口。2 JDK动态代理之Hello WorH我们要写一个程序,这个程序会在运行时动态的生成一个对象,这个对象会实现 Connection 接口。Connectoin c = (Connection)Proxy.newlnstance(Connetion.class);上面代码只是示意代码,不能编译通过的。上面代码有个问题:生成一个实现了指定接口的对象,但是我们知道实现接口,需要为 接口中每个方法添加实现内容,那么这个动态代理对象它是怎么实现Connection接口中的 方法的呢?也就是说,我现在如果调用了代理对象的close()方法,它会执行什么呢?这就是 问题!想生成

3、代理对象,还需要提供实现内容!别的先别去管,先來看一个接口: InvocationHandler。class HelloWorldHandler implements InvocationHandler public Object invoke (Object proxy, Method method, Object args) throws Throwable System, out .printin (Hello 动态代理!);return null;InvoactionHandler接口只有一个方法,invoke。!方法的参数你不要去管是什么意思,只 需要知道它只有一个方法,名字叫inv

4、oke(), 一会儿再去讨论它参数的含义。Connectoin c = (Connection)Proxy.newlnstance(Connetion.class, new HelloWorldHandler(); 上面代码还是示意代码,不能编译通过。我们这回在创建代理对彖时,多给出了一个参数,是一个接口的实现类。实现类中有一 条输出语句“Hello动态代理!”,现在生成的代理对象是Connection接口的实现类对象,你 调用代理对象的任何方法都会调用HelloWorldHandler的invoke。方法,即输出u Hello动态 代理! ”。Connectoin c = (Connecti

5、on)Proxy.newlnstance(Connetion.class, new HelloWorldHandler(); c.close();c.toStri ng();c.createStatement();还是示意代码!上面示意代码中调用了三个方法,无论哪个方法都会输出“Hello动态代理!”。现在你 知道InvocationHandler接口的作用了吧。public void fun2 () throws SQLException ClassLoader loader =Thread.current Thread() getContextClassLoAder();Class int

6、erfaces = Connection.class;InvocationHandler h = new HelloWorldHandler();Connec tion con = (Connec tion) Proxy nev/Pr oxy Instance (loader, interfaces, h);conclose();contoString();concreateStetement();3真正的代理虽然我们学会了动态代理,但还没有真正的代理。真正的代理是需要一个真正的连接对 象,然后我们的代理对象使用它来完成任务。为了说明这个真正的代理,需要写几个类: public interfa

7、ce Waiter public void serve();public class Waiterlmpl implements Waiter public void serve()System.out.printin(”月艮务);上面代码中写了一个Waiter接口,和一个Waiterlmpl,它是Waiter接口的实现类。现 在我们要写一个Waiterlmpl的代理类。public class WaiterProxy implements Waiter private Waiter waiter;public WaiterProxy(Waiter waiter) this.waiter =

8、waiter;public void serve()waiter.serve();上面代理中,WaiterProxy就是一个代理类,当然,这个代理类没有实际的意义,因为 它没有做任何的改变,所以没有意思!通常代理类是这样的,它会去实现一个接口,但它还 需要一个该接口的实现类对象,然后所有实现都使用这个对象来完成。象是上面的代理中, WaiterProxy是一个代理类,它实现了 Waiter接口,而且它还需要一个Waiter类型的对象, 然后所有的实现都是代理这个对彖功能。但是通常代理类会对被代理的对彖的一些行为做一 些改动,我们的例子中没有做。上面的WaiterProxy虽然是一个代理类,但它

9、不是动态代理。下面是通过JDK动态代理 来生成一个代理对象。public class WaiterHandler implements InvocationHandler private Waiter waiter;public WaiterHandler(Waiter waiter) this.waiter = waiter;public Object invoke(Object proxy, Method method, Object args) throws Throwable return method.invoke(waiter, args);ClassLoader loader =

10、Thread-currentThread() getContextClassLoader();Class interfaces = Waiter.class;Wai ter wAtier = new Wai terlmpl.();InvocationHandler h = new WaiterHandler(watier);Waiter proxy = (Waiter)ProxynewProxyInstance(loader, interfaces, h);proxyserve();4使用动态代理完成连接池public class ItcastDataSource implements Dat

11、aSource private private private privateString username;String password;String url;String driverClassName;private privateList list = new ArrayListConnection(); boolean flag = true;privatevoid init() throws SQLException flag = false;try ClassforName(driverClassName); catch(ClassNotFoundException e) throw new RuntimeException(e);for (int i = 0; i 0)return list.remove(0);throw new RuntimeException();

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号