Java数据库连接池

    当你的网站访问量很大的时候,数据库服务器在每一次连接时创建一次数据库连接,这样就浪费了很多的数据库资源,并且容易造成该数据库服务器内存溢出。数据库作为网站的核心模块,它的性能影响到了战歌网站的性能,数据库连接池可以解决这个问题:数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是新建立一个。

 

import java.sql.Connection;
import java.util.LinkedList;

import com.heima.utils.JdbcUtils;

public class MyConnectionPool{
    //创建一个连接池
  private static LinkedList<Connection> pool = new LinkedList<Connection>() ;
    
//初始化10个连接池
static{ for (int i = 0; i < 10; i++) { Connection conn = JdbcUtils.getConnection() ; //得到一个连接 pool.add(conn) ; } } //从池中获取一个连接 public synchronized static Connection getConnection(){ if(pool.size() > 0) return pool.removeFirst() ; //移除一个连接 else throw new RuntimeException("对不起,服务器忙") ; } //释放资源 public static void close(Connection conn){ if(conn != null) pool.addLast(conn) ; //放回池中 } }

 LinkedList<E>  List接口的链接列表实现。实现所有可选的操作,,并且允许所有元素(包括null)。除了实现List接口外,还为在列表的开头及结尾get,remove和insert元素提供了同意的命名方法。这些操作允许将链接列表用作堆栈、队列或双端队列。

注意:此实现不是同步的。

synchronized : java关键字,用来修饰一个方法或者一个代码块的时候,能够保证同一时刻最多只有一个线程执行该代码块。

posted @ 2016-11-29 10:04  kangjie  阅读(403)  评论(1编辑  收藏  举报