jdbc 基本操作

Posted graham-java

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jdbc 基本操作相关的知识,希望对你有一定的参考价值。

this.class.getClassLoader()解析

java是面向对象语言,面向对象的语言的宗旨就是万事万物皆对象,那么类、类里面的属性和方法都是对象。java里面的所有的类都是Class类的对象,this.class是获得这个类相对于Class类的对象。

getClassLoader()是获得这个类对象的加载器。只有Class类才有getClassLoader()方法;java设计Class这个类,用于虚拟机对类的管理。当一个类被虚拟机装载完毕的时候,就会创建一个Class类的实例,对于类A就是A.class,对于类B就是B.class。 Class类也提供了许多方法来获取类的信息。要知道,类的装载器分为 "启动类装载器 "、"用户定义装载器 "。它不止一种,Class类需要保存这些信息,getClassLoader()是用来获取这个信息的;
我们来看下面这个例子:
[java] view plain copy

URL fileURL = CollectionUtil.class.getClassLoader().getResource(fileName);  

这个类和这个方法没有直接的关系,只是当后面的fileName是一个相对路径的时候,就会在这个CollectionUtil类的当前位置开始查找资源文件;如果是个绝对路径的话,那前面的类是任意的Java类都可以了,因为.class.getClassLoader()是为了获得一个类加载器,用来加载classpath下的.class文件而已。getResource返回的是一个URL对象,不要简单的认为是这个资源的绝对地址,这是一个Java中封装的对象。

另外,提醒一下,很少是单独用上面这个URL对象的,一般是通过这个URL对象来构造Java中的FIle对象以及Icon对象等等,参考代码如下:

[java] view plain copy

File file3 = new File(Test.class.getClassLoader().getResource("javaapplication/file3.txt").getFile());  
String   icon   =   "../image/1.gif ";   
button.setIcon(new   ImageIcon(getClass() .getResource(icon)));  

Class.getResource和ClassLoader.getResource解析

Java中取资源时,经常用到Class.getResource和ClassLoader.getResource,这里来看看他们在取资源文件时候的路径问题。

Class.getResource()

[java] view plain copy

Class.getResouece(String path);  

path不以“/”开头时,默认是从此类所在的包下取资源;path以“/”开头时,则是从ClassPath根下获取;

观察如下示例:

文件结构如下:

如果我们想在Test.java中分别取1~3.xml文件,该怎么实现?

[java] view plain copy

package testpackage;  
  
public class TestMain {  
  
    public static void main(String[] args) {  
        // 当前类(class)所在的包目录  
        System.out.println(TestMain.class.getResource(""));  
        // class path根目录  
        System.out.println(TestMain.class.getResource("/"));  
  
    // TestMain.class在<bin>/testpackage包中  
        // 1.properties  在bin目录(class根目录)  
        System.out.println(TestMain.class.getResource("/1.properties"));  
          
        // TestMain.class在<bin>/testpackage包中  
        // 2.properties  在<bin>/testpackage包中  
        System.out.println(TestMain.class.getResource("2.properties"));  
          
        // TestMain.class在<bin>/testpackage包中  
        // 3.properties  在<bin>/testpackage.subpackage包中  
        System.out.println(TestMain.class.getResource("subpackage/3.properties"));  
          
    }  
}  

Class.getResource()和Class.getResourceAsStream()使用时,在路径选择上是一样的。

Class.getClassLoader().getResource(String path)

path不能以“/”开头时,是从ClassPath根下获取;

[java] view plain copy

package testpackage;  
public class TestMain {  
    public static void main(String[] args) {  
        TestMain t = new TestMain();  
        System.out.println(t.getClass());  
        System.out.println(t.getClass().getClassLoader());  
        System.out.println(t.getClass().getClassLoader().getResource(""));  
        System.out.println(t.getClass().getClassLoader().getResource("/"));//null  
    }  
}  

运行结果:
[java] view plain copy

class testpackage.TestMain  
[email protected]  
file:/E:/workspace/Test/bin/  
null  

还是上面的文件结构,使用Class.getClassLoader().getResourse(String path)该怎么实现呢?

[java] view plain copy

package testpackage;  
  
public class Test {  
    public static void main(String[] args) {  
        TestMain t = new TestMain();  
        System.out.println(t.getClass().getClassLoader().getResource(""));  
          
        System.out.println(t.getClass().getClassLoader().getResource("1.properties"));  
        System.out.println(t.getClass().getClassLoader().getResource("testpackage/2.properties"));  
        System.out.println(t.getClass().getClassLoader().getResource("testpackage/subpackage/3.properties"));  
    }  
}  

Class.getClassLoader().getResource()和Class.getClassLoader().getResourceStream()使用时,在路径选择上也是一样的。




以上是关于jdbc 基本操作的主要内容,如果未能解决你的问题,请参考以下文章

关于mysql驱动版本报错解决,Cause: com.mysql.jdbc.exceptions.jdbc4Unknown system variable ‘query_cache_size(代码片段

如何在片段中填充列表视图?

面试常用的代码片段

mysql jdbc源码分析片段 和 Tomcat's JDBC Pool

VSCode自定义代码片段——git命令操作一个完整流程

VSCode自定义代码片段15——git命令操作一个完整流程