Java ClassLoader 理解

ClassLoader理解

1.JVM结构和Java文件如何加载

  • JVM结构
  • 这里写图片描述

2.ClassLoader的介绍

  • 简介:类加载器 将class文件加载到jvm中区
  • 等级(加载器分为几种)
    • Bootstrap ClassLoader :主要是加载jvm自身的文件,是有c语言进行编写的,在程序中通常是不会进行使用的,主要进行加载rt.jar
    • ExtClassLoader :进行加载java.ext.dirs 目录下的文件
    • AppClassLoader: 使用广泛,加载的是我们classpath的文件
    • 自己定义的ClassLoader
  • 双亲委派机制:
    • 类加载器在加载class文件的时候,都会去找自己的parent的父类加载器(不是继承而是parent这个属性),查看父类是否能够记性加载,如果不能,在自身进行加载,如果找不到class文件,就会金星抛出错误。(详细使用源码进行分析)

3.ClassLoader源码分析

protected Class<?> loadClass(String name, boolean resolve)
        throws ClassNotFoundException
    {
        synchronized (getClassLoadingLock(name)) {
            // 1.第一步进行查看是否进行 name 这个类型是否已经被加载了
            Class<?> c = findLoadedClass(name);
            if (c == null) {
                long t0 = System.nanoTime();
                try {
                //2.如果没有进行父类classLoader进行加载
                    if (parent != null) {
                        c = parent.loadClass(name, false);
                    } else {
                        c = findBootstrapClassOrNull(name);
                    }
                } catch (ClassNotFoundException e) {
                    // ClassNotFoundException thrown if class not found
                    // from the non-null parent class loader
                }

                //如果父类的加载器都没有进行加载到的话 就进行自我加载
                if (c == null) {
                    // If still not found, then invoke findClass in order
                    // to find the class.
                    long t1 = System.nanoTime();
                    c = findClass(name);

                    // this is the defining class loader; record the stats
                    sun.misc.PerfCounter.getParentDelegationTime().addTime(t1 - t0);
                    sun.misc.PerfCounter.getFindClassTime().addElapsedTimeFrom(t1);
                    sun.misc.PerfCounter.getFindClasses().increment();
                }
            }
            if (resolve) {
                resolveClass(c);
            }
            return c;
        }
    }

ClassLoader 核心加载的方式就是loadClass():
1.第一步进行查看是否进行 name 这个类型是否已经被加载了
2.如果加载了进行直接返回
3.如果没有加载就去调用parent.loadClass()方法
4.从parent返回的为null,就行自己的路径下的加载

4.后记

  • 同一个类可以加载两次么?
    • 同一个类不能被同一个加载器加载两次,第二次进行加载的时候将会报错。同一个类可以被不同的类加载器进行加载。
  • JVM怎么判断是否是同一个类?
    • 1.类名是否完全相同
    • 2.是否由同一个类加载器进行加载的
  • ClassLoader能不能被回收
    • 可以进行回收,没有继续引用将会被GC调用。但是加载的文件就会被放入到PermGen区,注意PermGen的内存溢出
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ClassLoaderJava虚拟机(JVM)的一个重要组件,它负责在运行时动态加载Java类文件到内存中。ClassLoader的主要作用是根据类的全限定名(包括包名和类名)查找并加载对应的字节码文件,然后将字节码转换为JVM可以理解的运行时数据结构,最终生成可执行的Java类。 ClassLoader的工作原理是通过双亲委派模型来实现的。当一个类需要被加载时,ClassLoader首先会将请求委派给其父类加载器,如果父类加载器无法找到该类,则会尝试自己加载。这种层级关系的设计可以保证类的加载顺序和一致性,并且可以防止重复加载同一个类,提高了系统的安全性和效率。 ClassLoader可以根据不同的需求使用不同的实现,比如系统类加载器(Bootstrap ClassLoader)、扩展类加载器(Extension ClassLoader)和应用类加载器(Application ClassLoader)。系统类加载器负责加载JDK中的核心类库,扩展类加载器用于加载JDK扩展目录中的类库,而应用类加载器则负责加载应用程序的类。 除了默认的三种ClassLoaderJava还提供了自定义ClassLoader的能力,开发人员可以根据需要实现自己的ClassLoader来加载特定位置或者特定格式的类文件。自定义ClassLoader可以用于实现类似热部署、插件化等功能,扩展了Java的灵活性和可扩展性。 总之,ClassLoaderJava中起到了类加载的重要作用,它实现了类的动态加载和运行时的动态链接,为Java应用程序提供了更大的灵活性和可扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值