java中类的加载过程及各个阶段与运行时数据区中堆和方法区存储内容
java中类的加载过程
Java 类的加载是 JVM 将 字节码文件(.class 文件)加载到内存并最终转化为运行时数据的过程。它分为以下 五个主要阶段:加载、验证、准备、解析、初始化,每个阶段都有对应的内存位置存储相关信息。以下是类加载过程的详细描述,以及各阶段存储的信息和存储位置。
1. 加载(Loading)
过程描述:
- JVM 根据类的全限定名,通过类加载器(ClassLoader)找到字节码文件,并将其加载到内存中。
- 加载过程的核心任务是生成一个
Class对象,表示类的元信息。
主要内容存储:
- 类的字节码:
- 从文件系统、JAR 包、网络等位置加载
.class文件。
- 从文件系统、JAR 包、网络等位置加载
Class对象:- JVM 在方法区中为类生成一个运行时数据结构(元数据表),并在堆中创建一个对应的
java.lang.Class对象,以供程序使用。
- JVM 在方法区中为类生成一个运行时数据结构(元数据表),并在堆中创建一个对应的
存储位置:
- 方法区(由元空间实现):
- 存储类的结构和元信息。
- 堆:
- 存储生成的
Class对象。
- 存储生成的
2. 验证(Verification)
过程描述:
- JVM 验证字节码文件的正确性,确保其符合 JVM 的安全规范,避免恶意代码破坏虚拟机。
验证内容:
- 文件格式验证:
- 检查
.class文件是否符合 Class 文件格式规范(例如魔数0xCAFEBABE)。
- 检查
- 元数据验证:
- 验证类的元信息是否符合要求。
- 是否有父类(除
java.lang.Object外)。 - 接口、字段、方法是否符合规范。
- 是否有父类(除
- 验证类的元信息是否符合要求。
- 字节码验证:
- 检查方法体的字节码指令是否合法。
- 符号引用验证:
- 验证符号引用是否可以解析为实际的字段、方法或类。
存储位置:
- 方法区:
- 在验证过程中,类元数据结构可能会被进一步填充或更新。
- 运行时常量池:
- 符号引用的验证涉及运行时常量池中内容的检查。
3. 准备(Preparation)
过程描述:
- 为类的 静态变量 分配内存,并设置默认初始值(零值)。
- 不执行静态变量的赋值操作(赋值将在初始化阶段完成)。
处理内容:
-
静态变量:
-
例如:
class Example {static int a = 10; // 此阶段 a 的值为 0static final int b = 20; // b 会直接在常量池中赋值为 20 } -
静态变量
a被分配内存并初始化为默认值0,b(final修饰的常量)直接存储在运行时常量池中。
-
存储位置:
- 堆:
- 静态变量引用的对象存储在堆中。
- 方法区:
- 静态变量的初始值记录在方法区。
4. 解析(Resolution)
过程描述:
- 将运行时常量池中的 符号引用 转换为 直接引用。
- 符号引用是字面上的逻辑引用(例如类名、字段名),而直接引用是具体的内存地址或偏移量。
解析内容:
- 类或接口解析:
- 将符号引用的类名解析为方法区中对应的类元数据结构。
- 字段解析:
- 将字段名解析为具体字段的内存地址或偏移量。
- 方法解析:
- 将方法名和描述符解析为具体方法的字节码指针。
存储位置:
- 方法区:
- 符号引用存储在运行时常量池中,解析后的直接引用存储在类的元数据结构中。
- 堆:
- 解析的对象或方法指针可能引用堆内存中的对象实例。
5. 初始化(Initialization)
过程描述:
- 执行类的 () 方法,完成静态变量的赋值和静态代码块的执行。
<clinit>()方法是由编译器自动生成的,包含所有静态变量的显式赋值语句和静态代码块。
处理内容:
-
静态变量赋值:
-
静态变量被赋予程序中指定的初始值。
static int a = 10; // 此阶段 a 的值被设为 10
-
-
静态代码块:
-
执行静态代码块中的逻辑。
static {System.out.println("Class initialized!"); }
-
存储位置:
- 方法区:
- 静态变量的值更新存储在方法区。
- 堆:
- 静态变量引用的对象存储在堆中。
类加载过程中数据存储的总结
| 阶段 | 存储内容 | 存储位置 |
|---|---|---|
| 加载 | 字节码文件、类元数据(类名、字段、方法描述等)、生成 Class 对象。 | 方法区(元空间)存储类元数据,堆存储 Class 对象。 |
| 验证 | 验证 .class 文件和符号引用的合法性。 | 方法区(更新类元数据和常量池)。 |
| 准备 | 分配静态变量的内存,初始化默认值。 | 方法区存储变量描述,堆存储静态变量的实际值。 |
| 解析 | 符号引用解析为直接引用(类、字段、方法的实际地址)。 | 方法区(解析常量池符号引用)。 |
| 初始化 | 执行 <clinit>() 方法,完成静态变量赋值和静态代码块执行。 | 方法区存储最终结果,堆存储静态引用的对象。 |
补充:类加载的触发时机
类的加载可能在以下时机被触发:
- 主动引用:
- 创建类的实例(如
new操作符)。 - 访问类的静态字段或调用静态方法。
- 使用反射操作类。
- 创建类的实例(如
- 被动引用:
- 子类访问父类的静态字段时,只触发父类加载。
- 定义数组类型不会触发类加载。
类加载过程是 JVM 高效运行的基础,精确的存储分配和管理确保了类的正确运行和内存的优化使用。
相关文章:
java中类的加载过程及各个阶段与运行时数据区中堆和方法区存储内容
java中类的加载过程 Java 类的加载是 JVM 将 字节码文件(.class 文件)加载到内存并最终转化为运行时数据的过程。它分为以下 五个主要阶段:加载、验证、准备、解析、初始化,每个阶段都有对应的内存位置存储相关信息。以下是类加载…...
渗透测试--Web基础漏洞利用技巧
渗透测试--Web基础漏洞利用技巧 本文章写了Web基础漏洞中一些不那么常见的利用技巧,而不谈及漏洞的原理以及常见用法。 SQL 俺是SQLmap党,哈哈,所以这块就不多讲了。详情可见文章《渗透测试--SQLmap_渗透测试sqlmap-CSDN博客》 XXE XXE组成…...
SpringBoot下载文件的几种方式
小文件:直接将文件一次性读取到内存中,文件大可能会导致OOM GetMapping("/download1")public void download1(HttpServletResponse response) throws IOException {// 指定要下载的文件File file new File("C:\\Users\\syd\\Desktop\\do…...
教程:从pycharm基于anaconda构建机器学习环境并运行第一个 Python 文件
1. 安装 PyCharm 访问 PyCharm 官方网站:https://www.jetbrains.com/pycharm/。下载社区版(免费)或专业版(收费,提供更多功能)。按照操作系统的安装指导安装 PyCharm。安装后打开 PyCharm,并根…...
我用Ai学Android Jetpack Compose之Button
答案来自 通义千问,代码同样需要到Android Studio里实践,才能学会。完整工程代码见文末。 我要学Button,麻烦介绍一下 当然可以!Button 是 Jetpack Compose 中用于创建可点击按钮的 Composable 函数。它提供了丰富的配置选项来定…...
修改secure-file-priv参数-mysql5.7.26限制不允许导入或导出的解决方法
文章目录 前言secure_file_priv参数说明修改secure_file_priv参数的步骤 前言 本人是在sql注入的文件上传拿web shel 时所用到的写入文件权限遇到文件上传不成功的问题,记住修改后,重启mysql才生效,最后可以查看验证一下。 secure_file_priv…...
C# 设计模式(结构型模式):适配器模式
C# 设计模式(结构型模式):适配器模式 在软件开发中,我们经常会遇到需要将不同接口的组件结合在一起的情况。此时,适配器模式(Adapter Pattern)就派上了用场。它属于结构型设计模式,…...
Spring Cloud微服务多模块架构:父子工程搭建实践
一、前言 在现代微服务架构中,Spring Cloud 提供了一整套工具和技术栈来简化分布式系统的开发。为了更好地组织和管理复杂的微服务项目,使用 Maven 多模块(父子工程) 是一种高效的方法。 父子工程 是 Maven 中的一种项目结构…...
SkinnedMeshRenderer相关知识
SkinnedMeshRenderer和MeshRenderer unity中SkinnedMeshRenderer是CPU去更改顶点位置的。 而当使用MeshRenderer时,可以靠GPU来进行蒙皮(即更改顶点位置)。 SkinnedMeshRenderer是多线程处理的,在小程序游戏中,只支持…...
前端学习DAY30(水平)
子元素是在父元素的内容区中排列的,如果子元素的大小超过了父元素,则子元素会从 父元素中溢出,使用overflow属性设置父元素如何处理溢出的子元素 可选值:visible 默认值,子元素会从父元素中溢出,在父元素外…...
Spring boot 项目 Spring 注入 代理 并支持 代理对象使用 @Autowired 去调用其他服务
文章目录 类定义与依赖注入方法解析createCglibProxy注意事项setApplicationContext 方法createCglibProxy 方法 类定义与依赖注入 Service: 标识这是一个 Spring 管理的服务类。ApplicationContextAware: 实现该接口允许你在类中获取 ApplicationContext 对象,从而…...
Colyseus 与 HTTP API 的集成
Colyseus 与 HTTP API 的集成 在使用 Colyseus 开发实时多人应用时,通常需要与传统的 HTTP API 集成,例如用户身份验证、存储游戏数据、获取排行榜等。以下是 Colyseus 与 HTTP API 集成的详细介绍: 1. Colyseus 的基本架构 Colyseus 是一个…...
基于服务器部署的综合视频安防系统的智慧快消开源了。
智慧快消视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。国产化人工智能“…...
SpringBoot原理分析-1
SpringBoot原理分析 作为一个javaer,和boot打交道是很常见的吧。熟悉boot的人都会知道,启动一个springboot应用,就是用鼠标点一下启动main方法,然后等着就行了。我们来看看这个main里面。 SpringBootApplication public class E…...
HCIA-Access V2.5_7_5_XG(S)- GPON网络演进为XG(S)-PON网络
目前由于10 GPON ONU数量并没有得到大规模爆发,所以直接新建ODN网络成本相对较高,所以可以采用复用ODN的方案。 XG(S)-PON可以与GPON共享ODN 前面也介绍过GPON和10G GPON使用的波长,我们来回顾一下,在GPON网络中上行采用1310纳米波长,下行采用1490纳米的波长,而10G GPON…...
GPU算力平台的应用之任意门:任意穿搭匹配模型的应用教程
大家好,今天给大家介绍一下:GPU算力平台的应用之任意门:任意穿搭匹配模型的应用教程。 文章目录 一、GPU算力平台概述人工智能智能发展为什么需要GPU算力平台 二、注册与登录账号注册流程 三、平台的应用之Anydoor应用启动器选择Anydoor的应用场景Anydoo…...
如何利用人工智能算法优化知识分类和标签?
如何利用人工智能算法优化知识分类和标签? 聚类算法 原理与应用: 聚类算法是一种无监督学习算法,它可以根据数据的相似性将知识内容自动划分成不同的类别。例如,在文档知识库中,通过对文档内容的词向量表示应用 K -…...
Windows 11 系统中npm-cache优化
在 Windows 11 系统中,C:\Users\K\AppData\Local\npm-cache 文件夹是 npm(Node Package Manager) 用于缓存已下载的包的目录。缓存的存在可以加快包的安装速度,因为当再次安装相同的包时,npm 可以直接从缓存中获取&…...
Flink使用
Window下启动支持 下载或复制老版本的放在bin目录下即可; flink.bat echo off setlocalSET bin%~dp0 SET FLINK_HOME%bin%.. SET FLINK_LIB_DIR%FLINK_HOME%\lib SET FLINK_PLUGINS_DIR%FLINK_HOME%\pluginsSET JVM_ARGS-Xmx512mSET FLINK_JM_CLASSPATH%FLINK_LI…...
简易屏幕共享工具-基于WebSocket
前面写了两个简单的屏幕共享工具,不过那只是为了验证通过截屏的方式是否可行,因为通常手动截屏的频率很低,而对于视频来说它的帧率要求就很高了,至少要一秒30帧率左右。所以,经过实际的截屏工具验证,我了解…...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...
django filter 统计数量 按属性去重
在Django中,如果你想要根据某个属性对查询集进行去重并统计数量,你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求: 方法1:使用annotate()和Count 假设你有一个模型Item,并且你想…...
五年级数学知识边界总结思考-下册
目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解:由来、作用与意义**一、知识点核心内容****二、知识点的由来:从生活实践到数学抽象****三、知识的作用:解决实际问题的工具****四、学习的意义:培养核心素养…...
涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战
“🤖手搓TuyaAI语音指令 😍秒变表情包大师,让萌系Otto机器人🔥玩出智能新花样!开整!” 🤖 Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制(TuyaAI…...
AI编程--插件对比分析:CodeRider、GitHub Copilot及其他
AI编程插件对比分析:CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展,AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者,分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...
AI书签管理工具开发全记录(十九):嵌入资源处理
1.前言 📝 在上一篇文章中,我们完成了书签的导入导出功能。本篇文章我们研究如何处理嵌入资源,方便后续将资源打包到一个可执行文件中。 2.embed介绍 🎯 Go 1.16 引入了革命性的 embed 包,彻底改变了静态资源管理的…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
浪潮交换机配置track检测实现高速公路收费网络主备切换NQA
浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求,本次涉及的主要是收费汇聚交换机的配置,浪潮网络设备在高速项目很少,通…...
