클래스의 정규화된 이름(패키지 이름 + 클래스 이름)을 통해 클래스의 .class
파일을 가져와서 메타스페이스. .class
文件,加载到元空间。
验证:检验.class
文件的安全性
准备:为静态类型变量分配内存并设置默认值
解析:将常量池内的符号引用转换为直接引用,符号引用指向一个未被加载的类,或者未被加载类的字段或方法,那么解析将触发这个类的加载
执行类的构造器方法init
()的过程,若该类具有父类,jvm
会保证父类的init
先执行,然后在执行子类的init
。
启动类加载器是由C/C++语言实现的,用来加载Java核心类库。启动类只加载包名为:java、javax、sun开头的类
父类加载器为启动类加载器
。加载以下两个目录中的类库:
java.ext.dirs
目录
JDK安装目录:jre/lib/ext
目录
我们就可以将我们自己的包放在以上目录下,就会自动加载进来了。
父类加载器为启动类加载器
,负责加载环境变量classpath
或者系统属性java.class.path
指定路径下的类库,是程序中默认的类加载器,我们Java程序中的类,都是由它加载完成的。
继承java.lang.ClassLoader
类,重写findClass()方法 。如果没有太复杂的需求,可以直接继承URLClassLoader
类,重写loadClass
方法。
作用
加密:Java代码可以轻易的被反编译,如果你需要把自己的代码进行加密以防止反编译,可以先将编译后的代码用某种加密算法加密,类加密后就不能再用Java的ClassLoader去加载类了,这时就需要自定义ClassLoader在加载类的时候先解密类,然后再加载。
从非标准的来源加载代码:如果你的字节码是放在数据库、甚至是在云端,就可以自定义类加载器,从指定的来源加载类。
jvm对class文件采用的是按需加载的方式,当需要使用该类时,jvm才会将它的class文件加载到内存中产生class对象。在加载类的时候,是采用的双亲委派机制
。
如果一个类加载器
接收到了类加载
的请求,它自己不会先去加载,会把这个请求委托给父类加载器
去执行。
如果父类还存在父类加载器,则继续向上委托,一直委托到启动类加载器:Bootstrap ClassLoader
如果父类加载器可以完成加载任务,就返回成功结果,如果父类加载失败,就由子类自己去尝试加载,如果子类加载失败就会抛出ClassNotFoundException
异常,这就是双亲委派模式
打破双亲委派模型
用途:
Java应用中存在着很多服务提供者接口(Service Provider Interface,SPI),这些接口允许第三方为它们提供实现,如常见的 SPI 有 JDBC、JNDI等,这些 SPI 的接口属于 Java 核心库,一般存在rt.jar包中,由Bootstrap类加载器加载。而Bootstrap类加载器无法直接加载SPI的实现类,所以需要反向委派给其他类加载器进行加载
在Tomcat服务器中,存在一个服务器运行多个不同版本但同名服务的需求,所以需要打破双亲委派模型,加载多个同名类。
方法:
使用上下文类加载器
重写loadClass
.class
파일🎜🎜init의 실행이 트리거됩니다. code>(). A 클래스에 상위 클래스가 있고 <code>jvm
은 상위 클래스의 init
가 먼저 실행된 다음 하위 클래스의 init가 실행됩니다. 🎜🎜2. 클래스 로더🎜🎜<img src="https://img.php.cn/upload/article/000/465/014/168230238935730.png" alt="Java 클래스 로딩 프로세스와 클래스 로더란 무엇입니까?">🎜🎜스타트업 클래스 로더🎜🎜스타트업 클래스 로더는 C/C++ 언어로 구현되었으며 Java 코어 클래스 라이브러리를 로드하는 데 사용됩니다. 시작 클래스는 패키지 이름이 java, javax 및 sun으로 시작하는 클래스만 로드합니다. java, javax 및 sun🎜🎜확장 클래스 로더🎜🎜상위 클래스 로더는 <code>시작 클래스 로더
입니다. 다음 두 디렉터리에 클래스 라이브러리를 로드합니다.🎜java.ext.dirs
Directory🎜🎜🎜JDK 설치 디렉터리: jre/lib/ext
디렉터리🎜🎜🎜🎜위 디렉터리에 자체 패키지를 넣으면 자동으로 로드됩니다. 🎜🎜애플리케이션 클래스 로더🎜🎜부모 클래스 로더는 환경 변수 classpath
또는 시스템 속성 java.class.path시작 클래스 로더
입니다. /code> code> 지정된 경로 아래의 클래스 라이브러리는 프로그램의 기본 클래스 로더입니다. Java 프로그램의 모든 클래스는 이에 의해 로드됩니다. 🎜🎜사용자 정의 클래스 로더🎜🎜java.lang.ClassLoader
클래스를 상속하고 findClass() 메서드를 재정의합니다. 너무 복잡한 요구 사항이 없으면 URLClassLoader
클래스를 직접 상속하고 loadClass
메서드를 재정의할 수 있습니다. 🎜🎜기능🎜상위 위임 메커니즘
이 사용됩니다. 🎜클래스 로더
가 클래스 로딩
요청을 받으면 먼저 로드하지 않습니다. 요청은 실행을 위해 상위 클래스 로더
에 위임됩니다. 🎜🎜클래스 로더 시작: Bootstrap ClassLoader
🎜🎜ClassNotFoundException
예외가 발생합니다. 이것이 부모 위임 패턴
🎜🎜🎜🎜부모 위임 모델 깨기🎜🎜목적:🎜loadClass
메소드 재정의 🎜🎜🎜위 내용은 Java 클래스 로더 및 클래스 로딩 프로세스 개요의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!