欢迎来到天天文库
浏览记录
ID:40748690
大小:18.31 KB
页数:5页
时间:2019-08-07
《JVM加载机制2》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、JVM加载class文件的原理机制1.Java中的所有类,必须被装载到jvm中才能运行,这个装载工作是由jvm中的类装载器完成的, 类装载器所做的工作实质是把类文件从硬盘读取到内存中2.java中的类大致分为三种: 1.系统类 2.扩展类 3.由程序员自定义的类3.类装载方式,有两种 1.隐式装载,程序在运行过程中当碰到通过new等方式生成对象时,隐式调用类装载器加载对应的类到jvm中, 2.显式装载,通过class.forname()等方法,显式加载需要的类 隐式加载与显式加载的区别: 两者
2、本质是一样4.类加载的动态性体现 一个应用程序总是由n多个类组成,Java程序启动时,并不是一次把所有的类全部加载后再 运行,它总是先把保证程序运行的基础类一次性加载到jvm中,其它类等到jvm用到的时候再加载,这样的好处是节省了内存的开销,因为java最早就是为嵌入式系统而设计的,内存宝贵,这是一种可以理解的机制,而用到时再加载这也是java动态性的一种体现5.java类装载器 Java中的类装载器实质上也是类,功能是把类载入jvm中,值得注意的是jvm的类装载器并不是一个,而是三个,层次结构如下: Boo
3、tstrapLoader -负责加载系统类
4、 --ExtClassLoader -负责加载扩展类
5、 --AppClassLoader -负责加载应用类 为什么要有三个类加载器,一方面是分工,各自负责各自的区块,另一方面为了实现委托模型,下面会谈到该模型6.类加载器之间是如何协调工作的 前面说了,java中有三个类加载器,问题就来了,碰到一个类需要加载时,它们之间是如何协调工
6、作的,即java是如何区分一个类该由哪个类加载器来完成呢。 在这里java采用了委托模型机制,这个机制简单来讲,就是“类装载器有载入类的需求时,会先请示其Parent使用其搜索路径帮忙载入,如果Parent找不到,那么才由自己依照自己的搜索路径搜索类”,注意喔,这句话具有递归性 下面举一个例子来说明,为了更好的理解,先弄清楚几行代码: PublicclassTest{ Publicstaticvoidmain(String[]arg){ ClassLoaderc =Test.class.getClassLoader
7、(); //获取Test类的类加载器 System.out.println(c); ClassLoaderc1=c.getParent(); //获取c这个类加载器的父类加载器 System.out.println(c1); ClassLoaderc2=c1.getParent();//获取c1这个类加载器的父类加载器 System.out.println(c2); } } 把以上代码存到d:my文件夹下,直接编译,然后在dos模式下运行 D:myjavaTe
8、st 。。。AppClassLoader。。。 。。。ExtClassLoader。。。 NullD:my注:。。。表示省略了内容 可以看出Test是由AppClassLoader加载器加载的 AppClassLoader的Parent加载器是ExtClassLoader但是ExtClassLoader的Parent为null是怎么回事呵,朋友们留意的话,前面有提到BootstrapLoader是用C++语言写的,依java的观点来看,逻辑上并不存在BootstrapLoader的类实体,所以在java程序代码
9、里试图打印出其内容时,我们就会看到输出为null 【注:以下内容大部分引用java深度历险】 弄明白了上面的示例,接下来直接进入类装载的委托模型实例,写两个文件,如下: 文件:Test1.java PublicclassTest1{ Publicstaticvoidmain(String[]arg){ System.out.println(Test1.class.getClassLoader()); Test2t2=newTest2(); T2.print(); } }文件:Tes
10、t2.java PublicclassTest2{ Publicvoidprin(){ System.out.println(this.getClass().getClassLoader()); } }这两个类的作用就是打
此文档下载收益归作者所有