时间:2021-05-19
java 自己实现DataSource实现代码
DataSource 对象所表示的物理数据源的连接。作为 DriverManager 工具的替代项。DataSource能提供最高性能的对数据库的并发访问,数据源技术是Java操作数据库的一个很关键技术,流行的持久化框架都离不开数据源的应用。
数据源提供了一种简单获取数据库连接的方式,并能在内部通过一个池的机制来复用数据库连接,这样就大大减少了创建数据库连接的次数,提高了系统性能。下面,我们自己动手实现个精简的数据源,代码如下:
Java代码
public class MyConnection implements Connection{ private Connection connection; private MyDataSource datasource; public Connection getConnection() { return connection; } public void setConnection(Connection connection) { this.connection = connection; } public MyConnection(Connection realconnection,MyDataSource datasource){ this.connection=realconnection; this.datasource=datasource; } @Override public void close() throws SQLException { // TODO Auto-generated method stub System.out.println("MyConnection Close"); datasource.freeConnection(this); } ... }我们通过DataSource获得的Connection是经过包裹后的对象,这里应用到了代理模式。下面我们使用jdk的动态代理来改写MyDataSource:
Java代码
public class MyDataSource { private LinkedList<Connection> connectionPool = new LinkedList<Connection>(); public MyDataSource() { for (int i = 0; i < 10; i++) { connectionPool.add(GetProxy(creatConnection())); } } private Connection GetProxy(final Connection connection) { // TODO Auto-generated method stub return (Connection)Proxy.newProxyInstance(this.getClass().getClassLoader(), new Class[]{Connection.class}, new InvocationHandler(){ @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { // TODO Auto-generated method stub Object value; if(method.getName().equalsIgnoreCase("close")){ connectionPool.addLast((Connection)proxy); System.out.println(connectionPool.size()); return null; }else{ value=method.invoke(connection, args); } System.out.println(connectionPool.size()); return value; } }); } private Connection creatConnection() { try { return DriverManager.getConnection( "jdbc:mysql://localhost:3306/test", "root", "root"); } catch (SQLException e) { // TODO Auto-generated catch block throw new ExceptionInInitializerError(); } } public Connection getConnection(){ System.out.println(connectionPool.size()); return connectionPool.removeFirst(); } public void freeConnection(Connection conn){ System.out.println("DataSource Close Connection"); connectionPool.addLast(conn); } }通过这种方式获得的Connection是通过jdk的动态代理生成的一个代理对象,该代理对象实现了Connection接口。
以上两种方式实现了我们自己的DataSource,在我们通过DataSource获得的Connection对象的close方法都已经被改写过了。在Connection对象调用close方法时,会将该Connection对象放入到缓存池中,而不是关闭对象。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java使用Sqllite数据库如何生成db文件本文主要介绍Java使用Sqllite数据库如何生成db文件的实现实例,网上资料不是很多,自己上网搜资料看到的一
java简单的计算器程序实现实例:importjava.awt.*;importjava.awt.event.*;importjavax.swing.*;pub
C语言实现获取内存信息并输出的实例实现实例代码:headfile.h#include#include#include#defineTRUE1#defineFAL
在java开发中我们会经常的使用到外部资源,而外资源一般是通过接口的方式提供出来,那在java中我们怎么使用HttpClient实现post请求接口实现实现We
python实现自动远程登陆scp文件实例代码实现实例代码:#!/usr/bin/expectif{$argc!=3}{send_user"Usage:$arg