zoukankan      html  css  js  c++  java
  • 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关键字,用来修饰一个方法或者一个代码块的时候,能够保证同一时刻最多只有一个线程执行该代码块。

  • 相关阅读:
    还能这样偷懒?用Python实现网站自动签到脚本
    普通爬虫 VS 多线程爬虫!Python爬虫运行时间对比
    中文文献阅读方法及笔记模板
    约束
    可迭代对象补充
    练习题及补充
    内置函数的补充/super/异常值处理
    特殊成员
    嵌套
    面向对象知识点总结补充
  • 原文地址:https://www.cnblogs.com/taiguyiba/p/6112415.html
Copyright © 2011-2022 走看看