2021-10-12 第一讲: 程序运行时,内存如何分配?

本文解析Java程序执行过程中的内存布局,重点讲解了Java虚拟机栈、堆的作用,以及StackOverflowError和OutOfMemoryError的含义。介绍了栈帧的概念,并区分了不同数据区域的特性和线程共享性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、先来看一下,我们的代码是如何加载到内存中去的:

  1. 我们的Java文件在打包时,会被编译成对应的class文件,例如HelloWord.java文件会被编译为HelloWord.class文件,程序运行过程中,当使用到HelloWord这个类时,类加载器ClassLoader会把HelloWord.class 加载到内存中;

 2、Java虚拟机在执行Java程序的过程中,会把它所管理的内存划分为不同的数据区域,主要分为:程序计数器、虚拟机栈、本地方法栈、堆、方法区

3、异常状况:对于虚拟机栈这个区域,规定了两种异常状况,分别是:StackOverflowError和OutOfMemoryError;

StackOverflowError:当线程请求栈深度超出虚拟机栈所允许的深度时抛出(递归常见);

OutOfMemoryError:当Java虚拟机动态扩展到无法申请足够内存时抛出(打多发生在堆);

4、栈帧:用于支持虚拟机进行方法调用和方法执行的数据结构,每一个线程在执行某个方法时,都会为这个方法创建一个栈帧;(一个线程包含多个栈帧,每个栈帧内部包含局部变量表、操作数栈、动态链接、返回地址等

5、总结:

        上面介绍的5块内容(方法区、堆、虚拟机栈、本地方法栈、程序计数器)只是在Java虚拟机规范中定义的规则,这些规则只是描述了各个区域是负责做什么事情、存储什么样的数据、如何处理异常、是否允许线程间共享等,不是虚拟机的具体实现;总结来说,JVM运行时内存结构中一共有两个“栈”和一个“堆”,分别是:Java虚拟机栈和本地方法栈,以及“GC堆”和方法区;还有一个程序计数器我们平时几乎不会用到;此外,JVM中只有堆和方法区是线程共享的数据区域,其他区域都是线程私有的,程序计数器是唯一一个在Java虚拟机规范中没有规定任何OutOfMemoryError情况的区域;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值