JAVA类加载机制之Classloader以及打破加载机制的方式

本文详细介绍了JAVA类加载机制,包括JDK的双亲委派模型,如何通过继承ClassLoader和使用Thread的contextClassLoader来打破这一模型。同时,文章还探讨了JDK的并行类加载机制,以提升类加载速度。
摘要由CSDN通过智能技术生成

在jDK1.8中,Classloader加载class的字节码到JVM,它是遵循双亲委派模型的加载机制,主要是由BootstrapClassLoader,ExtClassLoader、AppClassloader,然后是自定义的Classloader加载,这样做主要是保证JDK的内部类加载安全性,所以优先加载JDK的ClassPath的jar包的类.双亲委派模型的如下图所示,其实就是由两级父Classloader加载,分别是BootstrapClassloader和ExtClassloader。

JDK的双亲委派模型

 

以下是Classloader的loadClass的和核心代码:

  1. 首先获取class的name的锁,是为了防止多线程并发的加载一个类,只有一个线程去加载,
  2. findLoadedClass获取JVM已经加载的缓存中该Classloader实例是否已经加载该类, JVM底层实际是SystemDictionary,其底层是HASH表实现。
  3. 如果JVM的缓存没有加载过这个className,则先交给parent加载器加载,

如果parent为空,则由BootstrapClassloader去加载,由于BootstrapClassloader是由C++实现,java没有这个类,所以通过JNI调用JVM的函数去加载。 4. 如果还没有加载到,则子类实现的findClass方法去加载。 5. 最后判断resolve参数,是否处理class的链接。 6. 最后返回class,没有加载到,由子类抛出ClassNotFoundException异常.

protected Class<?> loadClass(String name, boolean resolve)
    throws ClassNotFoundException
{
    synchronized (getClassLoadingLock(name)) {
        // First, check if the class has already been loaded
        Class<?> c = findLoadedClass(name);
        if (c == null) {
            long t0 = System.nanoTime();
            try {
                if (parent != null) {
                    c = parent.loadClass(name, false);
                } else {
                    c = findBootstrapClassOrNull(name);
                }
            } catch (ClassNotFoundException e) {
                // ClassNotFound
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值