首先看一下这个整体图,然后理解的记一下每个分区的功能
记这个有啥子用? 记住了,然后就可以祈祷面试官会问到你
1.1程序计数器
内存空间小,线程私有。可以把他当成当前线程的指示器,字节码解释器工作是就是通过改变这个计数器的值来选取下一条需要执行指令的字节码指令,分支、循环、跳转、异常处理、线程恢复等基础功能都需要依赖计数器完成
1.2Java 虚拟机栈
线程私有,生命周期和线程一致。描述的是 Java 方法执行的内存模型:每个方法在执行时都会创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用直至执行结束,就对应着一个栈帧从虚拟机栈中入栈到出栈的过程。
会存在:
StackOverflowError:线程请求的栈深度大于虚拟机所允许的深度。
OutOfMemoryError:如果虚拟机栈可以动态扩展,而扩展时无法申请到足够的内存。
1.3本地方法栈
和Java 虚拟机栈很相似,区别于 Java 虚拟机栈的是,Java 虚拟机栈为虚拟机执行 Java 方法(也就是字节码)服务,而本地方法栈则为虚拟机使用到的 Native 方法服务。也会有 StackOverflowError 和 OutOfMemoryError 异常。
1.4 Java 堆
对于大多数应用来说,这块区域是 JVM 所管理的内存中最大的一块。线程共享,主要是存放对象实例和数组。在虚拟机启动时创建。内部会划分出多个线程私有的分配缓冲区(Thread Local Allocation Buffer, TLAB)。可以位于物理上不连续的空间,但是逻辑上要连续。
-
堆里面还可以划分的
Java 堆是垃圾收集器管理的主要区域,由于现在收集器基本都是采用的分代收集算法,所以从内存回收的角度看,JVM又把Java 堆可以细分为:新生代和老年代;
GC 在老年代中采用标记-清除算法的Full GC ( 或称为 Major GC )和新生代中采用复制算法的Minor GC。新生代是 GC 收集垃圾的频繁区域;新生代 ( Young ) = 1/3 的堆空间大小,
老年代 ( Old ) = 2/3 的堆空间大小;而新生代被细分为 Eden 和 两个 Survivor 区域,这两个 Survivor 区域分别被命名为 from 和 to,以示区分。默认的,Edem : from : to = 8 : 1 : 1;
有人要问
:
来了一个数据,是怎么存储的呢?:数据会首先分配到Eden区当中(当然也有特殊情况,如果是大对象那么会直接放入到老年代(大对象是指需要大量连续内存空间的java对象)。),当Eden没有足够空间的时候就会 触发jvm发起一次Minor GC。如果对象经过一次Minor GC还存活,并且又能被Survivor空间接受,那么将被移动到Survivor空 间当中。并将其年龄设为1,对象在Survivor每熬过一次Minor GC,年龄就加1,当年龄达到一定的程度(默认为15)时,就会被晋升到老年代 中了,当然晋升老年代的年龄是可以设置的。
两个代各有啥子特点呢
?
新生代区域特点:
a) 绝大多数新创建的对象都存放在这个区域
b) 此区域一般来说较小而且JVM垃圾回收频率较高
c) 采用的算法和存放对象特点使得该区域JVM垃圾回收的效率也非常高老生代区域特点:
a) 将在"新生代"中生存了较长时间的对象转移过来
b) 区域一般要大一些而且增长的速度相对于"新生代"要慢一些
c) 垃圾回收的执行频率也会低很多
1.5方法区
属于共享内存区域,存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。(运行时常量池:属于方法区一部分,用于存放编译期生成的各种字面量和符号引用。编译器和运行期 都可以将常量放入池中。内存有限,无法申请时抛出 OutOfMemoryError。)
/
/
/
/
/
/
如果脑子还有地方,那就多记一个知识点
:
(咱也搞不懂在哪里会出现这句话,咱也不敢问)
-Xms2000m -Xmx2000m -Xmn800m -XX:PermSize=64m -XX:MaxPermSize=256m
Xms,即为jvm启动时得JVM初始堆大小,Xmx为jvm的最大堆大小,xmn为新生代的大小,
permsize为永久代的初始大小,MaxPermSize为永久代的最大空间。
整体回顾一下:
.
.
.
.
.本人通过百度,博客多处浏览截取,然后总结,如有侵权行为,请联系作者…