jvm

jvm 主要要理解的东西 主要是 jvm 分区 gc机制 和类的加载过程

今天总结jvm 分区

jvm 分区主要是分为 方法区,java 栈 本地方法栈 java 堆 和程序寄存器

程序寄存器就是一个指向器指向的是关于java 当前线程的字节码行数 在并发情况下每一个线程都会创建一个寄存器来独立计数相互不影响  应该是在分区里面唯一一个不报 oom 异常错误的 区域(他就是一个指向器所以根本不会报oom异常 哈哈) 当指向的是native 的方法是指向空

java虚拟机栈

在程序运行的时候一个方法就会建立一个栈针用于存放局部变量和操作数栈 和方法出口等信息 ,整个方法运行完成就是java 栈入栈和出栈的过程, 这个很明显是线程的私有内存 如果线程请求的栈的深度大于虚拟机栈的深度的话就会抛出StackOverflowError异常,如果虚拟机栈可以动态扩展(当前大部分的Java虚拟机都可动态扩展,只不过Java虚拟机规范中也允许固定长度的虚拟机栈),如果扩展时无法申请到足够的内存,就会抛出OutOfMemoryError异常

本地方法栈

他其实和java虚拟机栈特别相似 咱们的本地虚拟机要运行就要定于方法 那么就需要用到 本地方法栈,他们之间的区别是一个为java程序服务一个为 虚拟机服务。抛出异常跟Java栈一样

java 堆

他就是块共享内存 咱们创建出来的对象实例都在java堆上存放的,但是不是所有的对象都在java堆上释放,也会在方法区上存因为HotSpot公司实现的时候时候他将永久代放在了方法区上面。gc主要就是用在这里是内存调优的主要区域。

方法区

方法区(Method Area)与Java堆一样,是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据  对于习惯在HotSpot虚拟机上开发、部署程序的开发者来说,很多人都更愿意把方法区称为“永久代Permanent Generation),本质上两者并不等价,仅仅是因为HotSpot虚拟机的设计团队选择把GC分代收集扩展至方法区,或者说使用永久代来实现方法区而已,这样HotSpot的垃圾收集器可以像管理Java堆一样管理这部分内存,能够省去专门为方法区编写内存管理代码的工作

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值