JVM - 内存管理

Posted oscar1987121

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JVM - 内存管理相关的知识,希望对你有一定的参考价值。

JVM的内存管理主要分为两大块,每一块里面也会分为各自的部分

1. 线程共享区 - 这个等于所有线程,共享的一些内容

  • 程序计算器 - 这个就是程序运行时的一个代码读取器,用于管理和记录当前运行的代码
  • 栈 
    • Java虚拟机栈,方法执行的动态内存模型,每一个方法执行都会创建一个栈,用于记录局部变量表,操作数栈,动态链接,方法出口等,局部变量表在编译的过程中,已经分配好内存,在运行期间是不会改变局部变量的大小,一般如果遇到死循环,都会出现StackOverFlowError
    • 本地方法栈,与Java虚拟机栈差不多,区别是,Java虚拟机为JAVA 方法服务,而本地方法栈,就是提供native方法服务  

2. 线程独占区 - 这个等于线程内,自己独有的一些内容

  • 堆 - 存放实例对象,是垃圾回收最主要的区域
  • 方法区 - 加载的类信息,常量,静态变量,即时编译器编译后的代码, 方法区里面有一个常量池
    • 运行时常量池 - "abc"这样的创建字符串就会存放在常量池当中,如果new String("abc")就会存放在堆中

 

以上是关于JVM - 内存管理的主要内容,如果未能解决你的问题,请参考以下文章

JVM内存管理和JVM垃圾回收机制

Spark原理 内存管理

内存管理

内存管理

Java内存模型和JVM内存管理

详解JVM内存管理与垃圾回收机制 (上)