JVM随笔

JVM随笔:

  • JVM发展:Classic VM —>HotSpot VM+JRokit VM —>整合HotSpot VM(主流jvm)

  • JVM源码结构

  • JVM内存区域:

    JVM内存区域共分为5大块。分别为堆内存(Heap),方法区(Method Area),本地方法栈(Native Method Stack),虚拟机栈(JVMStacks)和程序计数器;
    堆内存:主要储存 java 方法在运行过程中 new 出来的对象->String str = new String();则new String()则存储于堆内存中,GC垃圾收集器(分代回收算法)主要工作于此区域,所有线程共享些区域,易出现OutOfMemoryError异常。

方法区:主要储存经过JVM加载之后的类信息class,常量 final,静态变量 static和编译后的代码等数据,垃圾回收器也将作用于此区域进行废弃数据回收。

虚拟机栈:主要储存局部变量(byte,boolean,char,short,float,int,double,long)以及对象的引用String str = new String()–>str,操作数栈,动态链接,方法出口等信息。每个java方法执行时会创建一个栈桢,栈桢的入栈到出栈 对应着一个java方法调用开始直至结束的过程。为 JVM执行java方法服务。操作数栈是JVM的一个工作区->加法运算->JVM使用指令将两个数从局部变量中提出来,然后压入到操作数栈中,再执行加法操作,最后将结果压入到操作数栈中,再将操作栈中的结果值储存到局部变量的索引中,以索引引出结果展示。

本地方法栈:主要储存程序中使用到的 Native方法(非java语言编写)—>java调用非java代码的接口:native public void Native1( int x ) ;

程序计数器:较小的内存区间,主要储存当前线程执行到某个位置,通过计数器的值来选择下一条需要执行的字节码指令,程序的分支,集合的循环,方法之间的跳转或者异常处理等都需要根据程序计数器来指定,每个线程独立拥有一个程序计数器。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值