动态代理实现数据库连接池功能(代理Connection的close方法)
2016-07-13 16:28
441 查看
package cn; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import java.sql.Connection; import java.sql.DriverManager; import java.util.LinkedList; /** * 在java种怎样实现动态代理呢 * 第一步,我们要有一个接口,还要有一个接口的实现类,而这个实现类呢就是我们要代理的对象, * 所谓代理呢也就是在调用实现类的方法时,可以在方法执行前后做额外的工作,这个就是代理。 * 第二步,我们要自己写一个在要代理类的方法执行时,能够做额外工作的类,而这个类必须继承InvocationHandler接口, * 为什么要继承它呢?因为代理类的实例在调用实现类的方法的时候,不会调真正的实现类的这个方法, * 而是转而调用这个类的invoke方法(继承时必须实现的方法),在这个方法中你可以调用真正的实现类的这个方法。 * 第三步,在要用代理类的实例去调用实现类的方法的时候,写出下面两段代码。 */ public class ZFXConnectionPool { //此list种放的就就是N个连接,此连接是动态代理过的connection,修改了原来close方法 private static LinkedList<Connection> listConnection = new LinkedList<Connection>(); static{ //*****************这句话可以在根目录生成代理类的class文件********* System.getProperties().put("sun.misc.ProxyGenerator.saveGeneratedFiles","true"); try { Class.forName("com.mysql.jdbc.Driver"); for(int i = 0 ;i<3;i++){ final Connection conn = DriverManager.getConnection("jdbc:mysql:///mysql", "root", "root"); Object obj = Proxy.newProxyInstance(ZFXConnectionPool.class.getClassLoader(), new Class[]{Connection.class}, new InvocationHandler() { public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { if("close".equals(method.getName())){ synchronized (listConnection) { listConnection.add((Connection) proxy); listConnection.notifyAll();//唤醒 return null; } }else{ //注意:第一个参数不能填 proxy , 因为proxy 是代理后的对象,会死循环执行invoke方法 return method.invoke(conn, args); } } }); listConnection.add((Connection) obj); } } catch (Exception e) { e.printStackTrace(); } } public static Connection getConn(){ synchronized (listConnection) { if(listConnection.size() == 0){ try { listConnection.wait(); } catch (InterruptedException e) { e.printStackTrace(); } return getConn(); }else{ return listConnection.removeFirst(); } } } }
相关文章推荐
- oracle日期函数2!
- Postgresql 异步流复制
- 部署SCCM2012之先SQL Server安装
- sql 语句的拼接
- mysql、oracle、sqlserver中只显示前几条记录的语法
- PowerDesigner 15设置mysql主键自动增长及基数
- 源码-PL/SQL从入门到精通-第二章-PL/SQL基本概念-Part 2
- redis实现消息队列
- 数据库中的五种约束及其添加方法
- mysql的mvcc(多版本并发控制)
- mongodb 复制集 维护小结
- HQL与SQL的区别
- SSH应用总结–插入
- 利用一个辅助变量来实现sql语句的拼接
- mongodb 复制集 维护小结
- Redis集群技术架构
- 如何导入导出MySQL数据库
- mysql数据库建立外键老是失败?
- 【hadoop】Hadoop,MapReduce操作Mysql(比较早的操作方法,可以看看)
- MySQL 加锁处理分析