创建c3p0连接池的原理

 public class JdbcUtils {

    private static DataSource dataSource;

    static {

        dataSource = new ComboPooledDataSource();
    }

    public static DataSource getDataSource() {

        return dataSource;
    }

    public static QueryRunner queryRunner() {

        return new QueryRunner(dataSource);
    }

}

请问一下,就是这上面这一段代码为什么能够创建连接池,并且能够顺利连接上数据库呢?这一段时间,自己写小项目,见得比较多,但是其中的原理不明白,所以想请问一下。拜谢!

你可以这样理解:相当于是下列代码,只不过使用properties文件要注意key值得前缀必须是c3p0;如 c3p0.driverClass=com.mysql.jdbc.Driver,可以看看源码
内部是自己读入properties文件得到数据库相关信息的
private static ComboPooledDataSource cpds = new ComboPooledDataSource();
static{
try {
cpds.setDriverClass("com.mysql.jdbc.Driver");
cpds.setJdbcUrl("jdbc:mysql://localhost:3306/createtable");
cpds.setUser("root");
cpds.setPassword("admin");
cpds.setInitialPoolSize(5);
} catch (Exception e) {
e.printStackTrace();
}
}

希望对你有帮助!