ClassLoader类加载器浅见

类加载器

类加载器,它拿到.class文件,它会把他拆成两部分,将static数据转换成方法区的数据结构,然后把他放在了方法区之中。
然后在堆里面建一个类对象(Class,它可以用来实例化对象),然后可以通过这个类对象找到位于方法区的static数据。、
注意:访问对象是从栈去找,然后在从访问对象,而这个堆分为两部分(堆,方法区(特殊的堆)).

  • package Reflection;
    public class Test05 {
        public static void main(String[] args) throws ClassNotFoundException {
            //获取系统类加载器
            ClassLoader systemClassLoader =ClassLoader.getSystemClassLoader();
            System.out.println (systemClassLoader);
            //测试父类加载器(Extention ClassLoader)
            ClassLoader parent = systemClassLoader.getParent ();
            System.out.println (parent);
            //扩展类加载器父类加载器,根(引导类)加载器,这个用户是获取不到的,最高一层
            ClassLoader gradepa = parent.getParent ();
            System.out.println (gradepa);
            //测试当前类是哪个加载器加载的
            ClassLoader classLoader = Class.forName ("Reflection.Test05").getClassLoader ();
            System.out.println (classLoader);
            //测试JDK内部类是由谁加载的,Object是最高级的了,创建它的类就是引导类加载器,也是不允许获取的
            classLoader = Class.forName ("java.lang.Object").getClassLoader ();
            System.out.println (classLoader);
            //获取java的扩展类
            System.out.println (System.getProperty("java.class.path"));
        }
    }
    结果:
        sun.misc.Launcher$AppClassLoader@dad5dc
        sun.misc.Launcher$ExtClassLoader@16d3586
        null
        sun.misc.Launcher$AppClassLoader@dad5dc
        null
        C:\jdk\jre\lib\charsets.jar;C:\jdk\jre\lib\deploy.jar;C:\jdk\jre\lib\ext\access-bridge.jar;C:\jdk\jre\lib\ext\cldrdata.jar;C:\jdk\jre\lib\ext\dnsns.jar;C:\jdk\jre\lib\ext\jaccess.jar;C:\jdk\jre\lib\ext\jfxrt.jar;C:\jdk\jre\lib\ext\localedata.jar;C:\jdk\jre\lib\ext\nashorn.jar;C:\jdk\jre\lib\ext\sunec.jar;C:\jdk\jre\lib\ext\sunjce_provider.jar;C:\jdk\jre\lib\ext\sunmscapi.jar;C:\jdk\jre\lib\ext\sunpkcs11.jar;C:\jdk\jre\lib\ext\zipfs.jar;C:\jdk\jre\lib\javaws.jar;C:\jdk\jre\lib\jce.jar;C:\jdk\jre\lib\jfr.jar;C:\jdk\jre\lib\jfxswt.jar;C:\jdk\jre\lib\jsse.jar;C:\jdk\jre\lib\management-agent.jar;C:\jdk\jre\lib\plugin.jar;C:\jdk\jre\lib\resources.jar;
    C:\jdk\jre\lib\rt.jar;
    D:\project\JavaTest2\out\production\JavaTest2;C:\Program Files\JetBrains\IntelliJ IDEA 2019.3.1\lib\idea_rt.jar
    
    
    

class对象在堆里面。对象一般都比较大,所以全放在堆里面(堆相当于一本书的内容部分)
自问自答:
类缓存?
顾名思义,就是一个类如果被放倒类加载器中,加载完了之后,还会保留一段时间。
类加载器分类?分三类(引导区加载器,扩展类加载器,系统类加载器),层次由高到底
测试当前类是哪个加载器加载的,测试JDK内置的类是由谁加载的,如何获得类加载器的加载路径?
ClassLoader返回的是一串字符串,先用ClassLoader.getSystemClassLoader可以获取系统类加载器,然后通过getParent()再往上获取。
双亲委派机制(就是优先启用系统原有的jar包,你写的就算一模一样他也不用。)!

类加载内存分析

public class Test03 {
    public static void main(String[] args) {
        A a = new A ();
        System.out.println (a.m);
    }
}
class A{
    static{
        m = 300;
        System.out.println ("静态方法在讲话,当前的m"+A.m);
    }
    static int m = 100;
    public A() {
        System.out.println ("构造方法启动了,当前的m"+m);
    }
}
结果:
    静态方法在讲话,当前的m=300
    构造方法启动了,当前的m=100
    100

posted @ 2020-04-18 17:21  li33的博客  阅读(204)  评论(0编辑  收藏  举报