JVM中classloader双亲委派

public class Test {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ClassLoader cl = Test.class.getClassLoader();
		while(cl!=null) {
			System.out.println(cl.getClass().getName());
			cl = cl.getParent();
		}
		System.out.println(cl);
	}

}

以上这段程序运行的结果是:

sun.misc.Launcher$AppClassLoader   -->表示Test类的类加载器是AppClassLoader

sun.misc.Launcher$ExtClassLoader     -->表示AppClassLoader的类加载器是ExtClassLoader

null                                 -->表示ExtClassLoader的类加载器是BootstrapClassLoader

classloader的体系结构如下

bootstrap classloader(java核心类) native  是由另外一种语言实现的本地方法

|

ext classloader(java 扩展类)

|

classpath appclassloader(应用路径下)

|

uri classloader(uri路径)

所以一般情况下,在classpath下的class都会通过appclassloader去加载

JVM中classloader双亲委派

时间: 2024-10-23 21:21:20

JVM中classloader双亲委派的相关文章

java安全沙箱(一)之ClassLoader双亲委派机制

java是一种类型安全的语言,它有四类称为安全沙箱机制的安全机制来保证语言的安全性,这四类安全沙箱分别是: 类加载体系 .class文件检验器 内置于Java虚拟机(及语言)的安全特性 安全管理器及Java API 本篇博客主要介绍下"类加载体系",介绍下它的基本原理并分享下jdk的实现源码:其它几类安全机制会在后续博客中陆续介绍. 类加载体系简介 "类加载体系"及ClassLoader双亲委派机制.java程序中的 .java文件编译完会生成 .class文件,而

一次尝试绕过ClassLoader双亲委派的实验

一.文章来由 来阿里玩Java也有一个多月了,一直对Java虚拟机比较感兴趣,而ClassLoader是整个class载入过程中很重要的组件.而classloader有个双亲委派模型,师兄说这个模型不能破坏,于是打赌一试. 相信如果问:为什么要双亲委派,可能有人可以侃侃而谈,但是说到为什么要这么分层,为什么要分三层,如何绕过双亲委派模型... 这就不是那么容易了,这个时候就需要一些专研了. 二.classloader的作用 这个问题我问了师兄:加载+连接的所有过程,但是深入理解Java虚拟机说的

深入JVM系列(三)之类加载、类加载器、双亲委派机制与常见问题

一.概述 定义:虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直接使用的java类型.类加载和连接的过程都是在运行期间完成的. 二. 类的加载方式 1):本地编译好的class中直接加载 2):网络加载:java.net.URLClassLoader可以加载url指定的类 3):从jar.zip等等压缩文件加载类,自动解析jar文件找到class文件去加载util类 4):从java源代码文件动态编译成为class文件 三.类加载的时机

为什么JVM的类加载要采用双亲委派的加载机制?

为什么JVM要采用双亲委派机制加载类呢? 任意一个类,都需要由加载它的类加载器和这个类本身一同确立其在Java虚拟机中的唯一性,每一个类加载器,都拥有一个独立的类名称空间. 也就是说,判断2个类是否“相等”,只有在这2个类是由同一个类加载器加载的前提下才有意义,否则即使这2个类来源于同一个Class文件,被同一个虚拟机加载,只要加载它们的类加载器不同,这2个类必定不相等. 基于双亲委派模型设计,那么Java中基础的类,Object类似Object类重复多次的问题就不会存在了,因为经过层层传递,加

java 类加载器   双亲委派机制

先上图,看一下加载器. 1.BootStrapClassLoader:启动类加载器,该ClassLoader是在启动时候创建的,是写在JVM内核里的,它不是一个字节码文件,是由c++编写的二进制代码,所以开发者无法获取到该启动类的引用,也就不能通过引用来进行操作.这个加载器是加载$JAVA_HOME/jre/lib下面的类库(或者通过参数-Xbootclasspath指定). 2.EXTClassLoader:扩展类加载器,ExtClassLoader会加载 $JAVA_HOME/jre/lib

[五]类加载机制双亲委派机制 底层代码实现原理 源码分析 java类加载双亲委派机制是如何实现的

Launcher启动类 本文是双亲委派机制的源码分析部分,类加载机制中的双亲委派模型对于jvm的稳定运行是非常重要的 不过源码其实比较简单,接下来简单介绍一下 我们先从启动类说起 有一个Launcher类   sun.misc.Launcher; 仔细看下这简短的几行注释,可以得到有用的信息 ps:直接IDE里面查看反编译的,看不到注释的,可以下载openJDK查看源码,我的这个版本是openjdk-8-src-b132-03_mar_2014 sun.misc.Launcher这个类是系统用于

【java基础】- java双亲委派机制

在了解双亲委派机制之前,你应当知道classloader(如果不了解,可以现在去恶补一下哈) 四种classloader 虚拟机自带 引导类加载器(Bootstrap ClassLoader) 扩展类加载器(Extension ClassLoader) 系统类加载器(Application ClassLoader) 用户自定义 用户自定义类加载器,需要继java.lang.ClassLoader package java.lang; public abstract class ClassLoad

JVM加载类的过程,双亲委派机制中的方法

JVM加载类的过程: 1)JVM中类的整个生命周期: 加载=>验证=>准备=>解析=>初始化=>使用=>卸载  1.1.加载 类的加载阶段,主要是获取定义此类的二进制字节流,并将这个字节流所代表的静态存储结构转化为方法区的运行时数据结构,最后在Java堆中生成一个代表这个类的java.lang.Class对象作为方法区这些数据的访问入口.相对于类加载过程的其他阶段,加载阶段是开发期可控性最强的阶段.我们可以通过定制不通的类加载器,也就是ClassLoader来控制二进制

[jvm解析系列][十]类加载器和双亲委派模型,你真的了解ClassLoader吗?

上一章我们讲到,一个类加载到内存里我们可以操作的部分只有两个,一个是加载部分一个是static{},我相信static{}不用多讲了. 接下来我们就来解析一下ClassLoader即类加载器,他就是用来加载字节码到方法区的类. 当年出现ClassLoader这个东西动态加载类的字节码主要还是为了满足JavaApplet的需求.虽然后来JavaApplet挂掉了,但是ClassLoader这个形式还是保留了下来,而且活的很好. 类的相等和instanceOf: 来我们来写一个例子 public c