前情提要:在学习JDBC部分知识时,为了解决数据库操作代码冗余问题,抽取冗余代码创建JDBC工具类
JDBC工具类主要包含获取数据库连接对象和导入jar包以及释放资源部分操作,将这些操作封装为相应的静态方法,在编写获取数据库连接对象的静态方法时,为了解决将代码写死的问题,我们采取静态代码块读取配置文件中的数据库信息,创建相应的数据库连接对象。
//成员变量是静态的,便于被静态方法和静态代码块所访问
private static String url;
private static String user;
private static String passwd;
private static String driver;
static {
try {
Properties pp = new Properties();
//获取src路径下文件的方式-->类加载器
ClassLoader classLoader = JDBCUtils.class.getClassLoader();
URL resource = classLoader.getResource("jdbc.properties");
String path = resource.getPath();
System.out.println(path);
pp.load(new FileReader(path));
url = pp.getProperty("url");
user = pp.getProperty("user");
passwd = pp.getProperty("passwd");
driver=pp.getProperty("driver");
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
} catch (IOException e) {
e.printStackTrace();
}
}
/*
文件的读取:避免每次调用方法都需要重新获取的繁琐,使用静态代码块,一次获取,多次使用
*/
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(url,user,passwd);
}
对以上代码块做出以下几点解释:
1.由于个人习惯不同,所以jdbc.properties文件存放的位置可能不同(我是直接放在src下的),所以如何动态获取src下jdbc.properties文件的绝对路径是我们需要解决的问题
//获取src路径下文件的方式-->类加载器
ClassLoader classLoader = JDBCUtils.class.getClassLoader();
URL resource = classLoader.getResource("jdbc.properties");
String path = resource.getPath();
类名.class将类加载进内存,getClassLoader方法获取类加载器
通过查阅百度,我了解了IEDA在编译运行时,会把src路径下的java文件进行编译并将编译后的字节码文件放在项目下的out\production\模块名文件夹中,还会把其他类型(除.java)的文件原样拷贝,一起放在项目下的out\production\模块名文件夹中.
那么,那么那么那么,由此我们可以知道
类加载器会从类路径查找类的字节码文件,所以可以借助类的加载器来加载文件从而找到文件路径