JVM内存结构|本地方法栈和堆

本地方法栈

在这里插入图片描述

  • 服务的对象是jvm执行的native方法,而虚拟机栈服务的对象
  • 当线程调用本地方法时,虚拟机会保持java栈不变,不再在线程的java栈中压入新的栈帧,虚拟机只是简单的动态连接并直接调用指定的本地方法。
  • Sun HotSpot 虚拟机直接把Java虚拟机栈和本地方法栈合二为一。
  • 与Java虚拟机栈一样,本地方法栈也会抛出StackOverflowError和OutOfMemoryError异常。
  • 程序计数器,虚拟机栈,本地方法栈都是线程私有的,不需要考虑线程安全问题。

Heap 堆

  • Java堆(Java Heap):是被所有线程所共享的一块内存区域,在虚拟机启动时创建。此内存区域的唯一目的就是:存放对象实例,几乎所有的对象实例都在这里分配内存。
  • 通过 new 关键字,创建对象都会使用堆内存
  • 它是线程共享的,堆中对象都需要考虑线程安全的问题
  • 有垃圾回收机制
  • (堆中不再被引用的对象会被当作垃圾回收)

堆内存溢出

如果在堆中没有完成实例分
配。并且堆也无法扩展时,将会抛出 OutOfMemoryError 异常。

堆内存诊断

  1. jps 工具
    查看当前系统中有哪些 java 进程
  2. jmap 工具
    查看堆内存占用情况 jmap - heap 进程id
  3. jconsole 工具
    图形界面的,多功能的监测工具,可以连续监测

猜你喜欢

转载自blog.csdn.net/qq_43941925/article/details/114357114