jvm知识点整理

内存区域划分:
1. 程序计数器,多核时,每个线程都会有一个独立的程序计数器,可以理解为是线程私有的
2. 虚拟机栈,也是每个线程私有的,生命周期和线程相同,描述的是java方法执行的内存模型。java方法在 执行时,会创建一个栈帧(方法的基本信息,局部变量,方法出口等)。方法从调用到执行完成的过程,对应着一个栈帧从虚拟机栈从入栈到出栈的过程。虚拟机栈溢出抛出的异常是StackOverflowError,当然也会抛出OOM,此时是因为线程请求的栈深度虽然没有达到虚拟机所允许的深度,但是在压栈时,无法申请到足够的内存。虚拟机栈可以理解为线程的工作内存。
3. 本地方法栈,和虚拟机栈类似,区别为本地方法栈是为本地方法 (Native)服务。
4. java 堆(heap),该内存区域为所有线程共享,是GC管理的主要区域。现在的垃圾回收机制主要有分代回收的思想。具体涉及到的垃圾回收算法在下一节中专门陈述。
5. 方法区,和java堆一样,该区域为各个线程所共享,用于存储已被虚拟机加载的类信息,常量,静态变量,即时编译器编译后的代码等数据。该区域 较少发生垃圾收集行为,在java虚拟机规范中也将方法区描述为堆的一个逻辑部分,很多人也愿意将方法区称为永久代。当方法区无法满足内存分配需求时,将抛出OOMError.
6. 运行时常量池,也是方法区的一部分,注意该区域是动态的。除了编译时产生的常量会进入外,运行期间也会产生新的常量进入,比如,String.intern()方法的调用。
7. 直接内存。NIO。
8.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值