类的加载器ClassLoader

类加载器是用来把类(class)装载进内存的。JVM 规范定义了如下类型的类的加载器。
image.png

类加载器的作用

  • 类加载的作用:将class文件字节码内容加载到内存中,并将这些静态数据转换成方法区的运行时数据结构,然后在堆中生成一个代表这个类的java.lang.Class对象,作为方法区中类数据的访问入口。
  • 类缓存:标准的JavaSE类加载器可以按要求查找类,但一旦某个类被加载到类加载器中,它将维持加载(缓存)一段时间。不过JVM垃圾回收机制可以回收这些Class对象。

    Java类编译、运行的执行的流程

    image.png
    1. public void test1() throws ClassNotFoundException {
    2. //1.获取一个系统类加载器
    3. ClassLoader classloader = ClassLoader.getSystemClassLoader();
    4. System.out.println(classloader);
    5. //2.获取系统类加载器的父类加载器,即扩展类加载器
    6. classloader = classloader.getParent();
    7. System.out.println(classloader);
    8. //3.获取扩展类加载器的父类加载器,即引导类加载器
    9. classloader = classloader.getParent();
    10. System.out.println(classloader);//null
    11. //4.测试当前类由哪个类加载器进行加载
    12. classloader = Class.forName("MyExer.PropertiesTest").getClassLoader();
    13. System.out.println(classloader);
    14. //5.测试JDK提供的Object类由哪个类加载器加载
    15. classloader = Class.forName("java.lang.Object").getClassLoader();
    16. System.out.println(classloader);//null
    17. //*6.关于类加载器的一个主要方法:getResourceAsStream(String str):获取类路径下的指定文件的输入流
    18. InputStream in = this.getClass().getClassLoader().getResourceAsStream("jdbc.properties");
    19. System.out.println(in);
    20. }

使用Classloader加载src目录下的配置文件

  1. public void test2() throws Exception {
  2. Properties pros = new Properties();
  3. //此时的文件默认在当前的module下。
  4. //读取配置文件的方式一:
  5. // FileInputStream fis = new FileInputStream("jdbc.properties");
  6. // FileInputStream fis = new FileInputStream("src\\jdbc1.properties");
  7. // pros.load(fis);
  8. //读取配置文件的方式二:使用ClassLoader
  9. //配置文件默认识别为:当前module的src下
  10. ClassLoader classLoader = ClassLoaderTest.class.getClassLoader();
  11. InputStream is = classLoader.getResourceAsStream("jdbc1.properties");
  12. pros.load(is);//从输入字节流读取属性列表(键和元素对)。
  13. String user = pros.getProperty("user");//根矩key(name)读取value
  14. String password = pros.getProperty("password");
  15. System.out.println("user = " + user + ",password = " + password);
  16. }