首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏强仔仔

    Tomcat8加载机制

    在了解加载机制时,发现网上大部分文章还停留在tomcat6,甚至tomcat5。 ? Tomcat8 和 Tomcat6比较大的区别是 : Tomcat8可以通过配置 <Loader delegate="true"/>不打破双亲委托 加载顺序略不同 概述 在 Java 环境中,加载器的布局结构是一种父子树的形式 Tomcat打破了双亲委派顺序 当某个请求想从 Web 应用的 WebappX 加载器中加载时,该类加载器会先查看自己的仓库,而不是预先进行委托处理 Tomcat8 JVM 的 Bootstrap Tomcat8加载顺序: 在加载时,先不进行委托,则每个应用会加载自己的(2/3 Web加载器) 加载不到时委托到再上层Common,Common再委托至System, 4 System加载到就返回, 遵循双亲委托 如果 Web 应用加载器配置有 <Loader delegate="true"/>,表示遵从双亲委托机制,同JVM,则加载顺序变为: JVM 的 Bootstrap System 加载器的

    1.6K10发布于 2019-05-25
  • 来自专栏老铁丁D

    加载机制

    加载机制 加载过程总的来说分为7个过程:加载,验证,准备,解析,初始化,使用,卸载,其中的验证,准备,解析又称为连接阶段 java虚拟机规范并没有规定什么时候要进行加载阶段,但是规定了什么时候必须进行初始化阶段 加载器只用于实现加载动作。对于任意一个,都需要由加载它的加载器和这个本身一同确立其在Java虚拟机中的唯一性,每一个加载器,都拥有一个独立的名称空间。 从开发人员的角度加载器有三种:启动加载器,扩展加载器,应用程序加载器 启动加载器:负责将存放在<JAVA_HOME>\lib目录中的加载到虚拟机内存中 扩展加载器:负责将存放在<JAVA_HOME >\lib\ext目录中的加载到虚拟机内存中 应用程序加载器:它负责加载用户路径(ClassPath)上所指定的库 双亲委派机制 加载器之间如下图的这种层次关系,称为加载器的双亲委派模型。 双亲委派模型的工作过程:如果一个加载器收到了加载的请求,它首先不会自己去尝试加载这个,而是把这个请求委派给父加载器去完成,每一个层次的加载器都是如此,因此所有的加载请求最终都应该传送到顶层的启动加载器中

    69320编辑于 2022-08-12
  • 来自专栏Apache IoTDB

    加载机制

    加载具体机制可以参考: Java加载机制: https://zhuanlan.zhihu.com/p/25228545 JVM 基础 - Java 加载机制: https://www.pdai.tech /md/java/jvm/java-jvm-classload.html 2 加载机制 2.1 双亲委派机制 双亲委派机制是指如果一个加载器收到了加载的请求,它首先不会自己去尝试加载这个,而是把请求委托给父加载器去完成 2.2 全盘负责机制 当一个加载器负责加载某个 Class 时,该 Class 所依赖的和引用的其他 Class 也将由该类加载器负责载入,除非显式使用另外一个加载器来载入。 2.3 缓存机制 缓存机制将会保证所有加载过的 Class 都会被缓存,当程序中需要使用某个 Class 时, 加载器先从缓存区寻找该 Class, 只有缓存区不存在,系统才会读取该类对应的二进制数据 结合加载机制中的全盘负责机制,我们知道这个匿名是由加载依赖它的 org.apache.iotdb.MySum 的加载器来加载的,我们把这个加载器记为 A。

    85610编辑于 2023-03-21
  • 来自专栏only theone 的记录

    加载机制

    1.访问的编译期静态常量时,不会触发的初始化行为。的初始化行为是指在加载之后(也就是的Class对象被创建之后),为的静态成员变量分配存储空间。 2.编译期静态常量会在编译阶段被存储到NonInitialization的常量池中,在以后对编译期静态常量的引用都实际上被替换为对NonInitializaion对自身常量池的引用,所以访问的编译期静态常量并不会触发的初始化行为 3.初始化一个之前,会先初始化该类的父

    45710发布于 2019-11-21
  • 来自专栏Panda诚

    加载机制

    加载机制 Java虚拟机把描述的数据从Class文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这个过程被称作虚拟机的加载机制。 CONSTANT_Utf8_info型的常量中是否有不符合UTF-8编码的数据。 Class文件中各个部分及文件本身是否有被删除的或附加的其他信息。 验证阶段对于虚拟机的加载机制来说,是一个非常重要的、但却不是必须要执行的阶段,因为验证阶段只有通过或者不通过的差别,只要通过了验证,其后就对程序运行期没有任何影响了。 ,在JDK 7及之前,HotSpot使用永久代来实现方法区时,实现是完全符合这种逻辑概念的;而在JDK 8及之后,变量则会随着Class对象一起存放在Java堆中,这时候“变量在方法区”就完全是一种对逻辑概念的表述了 当一个接口中定义了JDK 8新加入的默认方法(被default关键字修饰的接口方法)时,如果有这个接口的实现发生了初始化,那该接口要在其之前被初始化。 参考:深入理解Java虚拟机

    93320发布于 2020-09-01
  • 来自专栏晏霖

    加载机制

    点击上方“晏霖”,选择“置顶或者星标” 曾经有人关注了我 后来他有了女朋友 1.6加载机制 1.6.1概述 学习本章前我们要对文件结构有一个简单的认识,而学习文件结构没有任何难度,更多的是参考《 n 验证 验证是连接的第一步,这个阶段主要是校验class文件的字节流包是否符合《Java虚拟机规范》所规定的,是虚拟机自身保护的机制。 n 准备 该阶段主要为变量分配内存并设置初始值,JDK8前都是在方法区分配都,但JDK8后变量会随着对象一起存放在Java堆。 图1-33 静态代码块与静态方法字节码文件示例 1.6.4加载器 在讲加载过程的加载阶段时提到过加载器,加载器的作用就是实现加载阶段的任务,通过一个的全限定名获取Class文件的二进制字节流, 代码清单1-2 加载机制源码 //ValueUtility.java static { SharedSecrets.setJavaCorbaAccess(new JavaCorbaAccess

    58020发布于 2020-11-24
  • 来自专栏全栈程序员必看

    JVM 加载机制_加载机制的作用和过程

    事实上,虚拟机把描述的数据从Class文件加载到内存,并对数据进行校验,转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型的过程就是虚拟机的加载机制。 对于jvm加载机制,我们主要关注两个问题: 加载时机?(初始化的五种情况) 加载过程? (的五个加载过程) 二、加载时机 1.的生命周期 从被加载到虚拟机内存中开始,到卸载出内存为止,整个生命周期包括加载、验证、准备、解析、初始化、使用和卸载。 2.加载时机 这里的“加载”只是加载过程的一个阶段,代表这“加载”的这一过程的开始,jvm并没有强制性约束在什么时候开始加载过程。 一般我们说加载,指的是整个加载过程。 (Child.cons); } //输出 55 三、加载过程 1.加载 加载”是由加载器完成的“加载过程”的第一个阶段,在初始化之前完成。

    81420编辑于 2022-09-23
  • 来自专栏用户5325874的专栏

    加载机制总结

    加载机制 虚拟机把描述的数据从class文件加载到内存,并且进行校验、解析、初始化。最终形成可以直接使用的Class对象,这就是加载机制。 当用户在自己的代码中,需要某些额外的时,再通过加载机制加载到JVM中,并且存放一段时间,便于频繁使用。 根据加载机制,当被加载引用了另外一个的时候,需要使用第一个加载器进行加载。 (只有ClassLoader被卸载了,对应的才能被卸载) WebappClassLoader的加载逻辑 tomcat的加载机制是违反了双亲委托模型的,各个web应用自己的加载器(WebAppClassLoader from=singlemessage [Tomcat加载机制

    71620发布于 2020-01-16
  • 来自专栏学习

    【JVM】加载机制

    加载机制 加载指的是,Java 进程运行的时候,需要把 .class 文件从硬盘读取到内存,并进行一些列的校验解析的过程(程序要想执行,就得进入内存) .class 文件==>对象 硬盘==>内存 加载过程 加载的过程,其实是在 Java 官方文档中给出的说明 加载:找到. class 文件,并且读文件内容 验证:校验 .class 文件的格式是否符合 JVM 规范要求 准备:给对象分配内存 (此时内存空间全是 0 的==>的静态成员也就是全 0 的值) 解析:针对中的字符串常量进行处理 把对象的各个属性进行赋值填充==>触发对父加载,初始化静态成员,执行静态代码块 加载大体的过程可以分为五 当前需要确保读到的文件的内容是合法的 .class 文件(字节码文件)格式 具体的验证依据,在 Java 虚拟机规范中,有明确的格式说明: https://docs.oracle.com/javase/specs/jvms/se8/ 初始化 针对对象完成后续的初始化 还要执行静态代码块的逻辑,还可能会触发父加载

    25110编辑于 2024-10-15
  • 来自专栏木木玲

    加载机制”详解

    概述 虚拟机的加载机制:虚拟机把描述的数据从Class文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型。 同时,通过“-XX:+TraceClassLoading”打印被加载加载信息,发现MyParent2没有被加载!! (在JDK 8中Class对象会被放在“元空间”) ③ 在内存中生成一个代表这个的java.lang.Class对象,作为方法区这个的各种数据的访问入口。 关于“非数组”的加载: 相对于加载过程的其他阶段,一个非数组加载阶段(准确地说,是加载阶段中获取的二进制字节流的动作)是开发人员可控性最强的,因为加载阶段既可以使用系统提供的引导加载器来完成 ② 元数据验证; ③ 字节码验证; ④ 符号引用验证 对于虚拟机的加载机制来说,验证阶段是一个非常重要的、但不是一定必要(因为对程序运行期没有影响)的阶段。

    1.2K10发布于 2018-06-27
  • 来自专栏JAVA基础知识

    Java加载机制

    Java加载机制是指 JVM 把的字节码文件加载到内存,并进行链接和初始化的过程。 加载加载是“加载”(Class Loading)过程的一个阶段,是通过双亲委派机制进行加载。 对于任意一个,都需要由加载它的加载器和这个本身一同确立其在Java虚拟机中的唯一性,每一个加载器,都拥有一个独立的名称空间。加载器可分为启动加载器、扩展加载器和应用加载器。 它负责加载用户路径(ClassPath)上所指定的库,开发者可以直接使用这个加载器,如果应用程序中没有自定义过自己的加载器,一般情况下这个就是程序中默认的加载器。 加载模型双亲委派模型如果一个加载器收到了加载的请求,它首先不会自己去尝试加载这个,而是把这个请求委派给父加载器去完成,每一个层次的加载器都是如此,因此所有的加载请求最终都应该传送到顶层的启动加载器中

    52910编辑于 2024-10-14
  • 来自专栏Java架构师必看

    JVM 加载机制

    其中加载的过程包括了加载、验证、准备、解析、初始化五个阶段。 加载: 查找并加载的二进制数据 加载加载过程的第一个阶段,在加载阶段,虚拟机需要完成以下三件事情: 【1】通过一个的全限定名来获取其定义的二进制字节流。 加载器并不需要等到某个被“首次主动使用”时再加载它,JVM规范允许加载器在预料某个将要被使用时就预先加载它,如果在预先加载的过程中遇到了.class文件缺失或存在错误,加载器必须在程序首次主动使用该类时才报告错误 (LinkageError错误)如果这个一直没有被程序主动使用,那么加载器就不会报告错误。 在 Java中对变量进行初始值设定有两种方式: 【1】声明变量时指定初始值; 【2】使用静态代码块为变量指定初始值; JVM初始化步骤: 【1】假如这个还没有被加载和连接,则程序先加载并连接该类

    81020发布于 2021-05-14
  • 来自专栏Python程序员杂谈

    java加载加载机制

    在沙箱组件中包括装载器结构,加载器体系结构也是java沙箱的第一道防线,因为程序都是通过加载器才能够加载到JVM中的。   加载器有三方面的作用: 1. 它防止了恶意代码去干涉善意代码 2. 其中一个大家所熟悉的词就是“双亲委派机制”,所谓“双亲委派机制”,就是某个特定的加载器在接到加载的请求时,首先将加载任务委托给父加载器,依次递归,如果父加载器可以完成加载任务,就成功返回;只有父加载器无法完成此加载任务时  扩展加载器(extensions class loader):它用来加载 Java 的扩展库。Java 虚拟机的实现会提供一个扩展库目录。该类加载器在此目录里面查找并加载 Java 。  系统加载器(system class loader):它根据 Java 应用的路径(CLASSPATH)来加载 Java 。一般来说,Java 应用的都是由它来完成加载的。 关于java加载机制推荐大家看这篇文章《深入探讨 Java 加载器》,IBM文档,写的很详细。

    1.4K10发布于 2019-02-28
  • 来自专栏酒楼

    JVM加载机制

    JVM加载机制 java虚拟机把描述的数据从Class文件加载到内存,并对数据进行校验,转换解析和初始化,最终形成可以被虚拟机直接使用的java类型,这就是虚拟机的加载机制。 1.加载(loading) (1)查找和导入class文件 的装载指的是将的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个java.lang.Class 加载的最终产品是位于堆区中的Class对象,Class对象封装了在方法区内的数据结构,并且向Java程序员提供了访问方法区内的数据结构的接口。 (2)加载.class文件的方式 ​ 1.从本地系统中直接加载 ​ 2.通过网络下载.class文件 ​ 3.从zip,jar等归档文件中加载.class文件 ​ 4.从专有数据库中提取.class 5.初始化(Initialization) 对的静态变量,静态代码块执行初始化操作 步骤: 1.加入这个还没有被加载和连接,则程序先加载并连接该类 2.加入该类的直接父还没有被初始化,则先初始化其直接父

    46710编辑于 2023-12-30
  • 来自专栏Leetcode名企之路

    jvm加载机制

    加载机制:虚拟机把描述的数据从class文件加载,并对数据进行校验、转换解析、初始化,最终形成可以被虚拟机直接使用的java类型。 加载过程 其中加载的过程包括了加载、验证、准备、解析、初始化五个阶段。 加载器 说到加载,那jvm是怎么把这些数据加载到内存的呢?答案是:通过加载器。java中提供了这么几种类加载器: 启动加载器:Bootstrap ClassLoader,跟上面相同。 双亲委派模型 如果一个加载器收到了加载的请求,它首先不会自己去尝试加载这个,而是把请求委托给父加载器去完成,依次向上,因此,所有的加载请求最终都应该被传递到顶层的启动加载器中,只有当父加载器在它的搜索范围中没有找到所需的时 例如,java.lang.Object存放在JDK\jre\lib下的rt.jar之中,因此无论是哪个加载器要加载此类,最终都会委派给启动加载器进行加载,这边保证了Object在程序中的各种类加载器中都是同一个

    69630发布于 2018-11-29
  • Java加载机制

    加载的时候,是采用的双亲委派机制,即把请求交给父处理的一种任务委派模式。工作原理(1)如果一个加载器接收到了加载的请求,它自己不会先去加载,会把这个请求委托给父加载器去执行。 下面给大家列举一下,破坏双亲委派机制最常见的场景。3.1 JNDIJNDI是Java中的标准服务,它的代码由启动加载器去加载。 有了线程上下文加载器,JNDI服务就可以使用它去加载所需要的SPI代码,也就是父加载器请求子类加载器去完成加载的动作,这样就打破了双亲委派机制。 也就是说,有些公共的依赖包,最好能够只加载一次。我们还需要将Tomcat本身的,跟Web应用的隔离开。这些原因导致,Tomcat没有办法使用传统的双亲委派机制加载了。 那么,Tomcat加载机制是怎么样的?CommonClassLoader:是Tomcat最基本的加载器,它加载可以被Tomcat容器和Web应用访问。

    58900编辑于 2024-11-27
  • 来自专栏Java编程指南

    JVM加载机制

    1、如果数据的组件类型不是引用类型,虚拟机会把数组标记为与引导加载器关联。 2、如果数组的组件类型是引用类型,数组将在加载该组件类型的加载器的名称空间上被标识。 ? ? 七、加载器 任意一个,都需要由加载它的加载器和这个本身一同确立其在JVM中的唯一性。 如果一个加载器收到了加载的请求,首先不会自己尝试去加载这个,而是将请求委派给父加载器去完成,所有的加载请求最终都传送到启动加载器,只有父加载器反馈无法加载,子加载器才会尝试自己加载。 双亲委派模型的特殊情况: 1、代码热替换、模块热部署,OSGi实现模块化热部署的关键是它自定义的加载机制的实现。 SPI代码,父加载器请求子类加载器取完成加载,违背双亲委派模型。

    75930发布于 2019-08-02
  • 来自专栏程序猿杂货铺

    JVM加载机制

    概述 虚拟机把描述的数据从CLass文件加载到内存,并对数据进行校验,解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就是虚拟机的加载机制(懒加载)。 加载过程 加载--连接--初始化--使用--卸载 JVM加载机制 1. (5)CONSTANT_Utf8_info型的常量中是否有不符合UTF8编码的数据。 (6)Class文件中各个部分及文件本身是否有被删除的或附加的其他信息。 整体类型是: byte,其值为8位有符号二进制补码整数,其默认值为零 short,其值为16位有符号二进制补码整数,其默认值为零 int,其值为32位有符号二进制补码整数,其默认值为零 long,其值为 (因为Object是所有的父) 双亲委派模型 通俗的讲,就是某个特定的加载器在接到加载的请求时,首先将加载任务委托给父加载器,依次递归,如果父加载器可以完成加载任务,就成功返回;只有父加载器无法完成此加载任务时

    83930发布于 2019-09-03
  • 来自专栏Coding Diary

    Java加载机制

    Java的程序要运行需要将编译好的class文件加载到JVM运行时数据区。 ? 在了解加载机制之前,我们需要了解一下的生命周期。 加载器 Java加载需要用到加载器。加载器负责装入,搜索网络,jar,zip,文件夹,二进制数据,内存等指定位置的资源。 一个Java程序运行,至少有3个不同的加载器实例,负责加载不同的。 双亲委派模型 Java中的并不会重复加载,同一加载器,同一名,代表的是同一个。而避免重复加载的主要原因在于JVM在加载时默认采用的是双亲委派模型。 所谓的双亲委派模型,就是某个特定的加载器在接到加载请求时,首先将加载任务委托给父加载器,依次递归,如果父加载器可以完成加载任务,就成功返回;只有父加载器无法完成此加载任务时,才自己去加载

    72810发布于 2019-10-10
  • 来自专栏JAVA乐园

    Java加载机制

    } 编译成功后,用xxd test.class 命令可以查看一下这个字节码文件 00000000: cafe babe 0000 0038 0010 0a00 0300 0d07 .......8. 3.1 加载机制 ? 缓存机制:缓存机制会保证所有加载过的Class都会被缓存,当程序中需要使用某个时,加载器先从缓冲区搜索该类,若搜寻不到将读取该类的二进制数据并转换成Class对象存入缓冲区中。 changed 可见,在JDK 9中,应用程序加载器可以委托给平台加载器以及引导加载器;平台加载器可以委托给引导加载器和应用程序加载器。 此外,JDK 9不再支持扩展机制。 JDK 9中的加载机制有所改变。三个内置的加载器一起协作来加载。 JDK 9中的加载机制有所改变。三个内置的加载器一起协作来加载。 JDK 9中的加载机制有所改变。

    1.3K30发布于 2021-02-03
领券