java JVM详解

一、栈
存放临时变量、参数和中间结果

二、方法区
要加载的类信息、静态变量、常量等等,使用permanent generation存放方法区

三、堆有三部分组成:(1)young generation (2)old generation (3)permanent generation
1、young generation有三部分组成:eden space 、from space 、to space;其中from space和to space构成survivor
(1)新创建的对象都是使用young generation的内存,当eden区空间不足时,会触发minor GC,把存活的对象转移进survivor区
(2)通常基于copying算法进行回收,即扫描出存活的对象,并复制到一块新的完全未使用的空间中,对应于新生代,就是在Eden和FromSpace或ToSpace之间copy。

2、old generation
(1)存放经过多次minor GC之后依然存活的对象,当old generation空间不够时,会触发major GC

四、GC收集器
并行收集器:用户线程处于等待状态,多个GC线程并行工作,应用程序会出现停顿
并发收集器:用户线程和GC线程同时执行,在多核CPU上,应用程序不会出现停顿
-Xmx :最大堆大小
-Xms :初始堆大小
-Xmn :young generation大小
-Xss :栈大小
-XX:+UseParallelGC :young generation并行,old generation串行
-XX:+UseParNewGC :young generation并行,old generation串行
-XX:+UseParallelOldGC :young generation和old generation都是并行
-XX:ParallelGCThreans = 20:配置并行收集器的线程数,可以等于处理器数目
-XX:+UseConcMarkSweepGC :设置年老代为并发收集,可以与-XX:+UseParNewGC同时使用
-XX:CMSFULLGCsBeforCompaction=5 :由于并发收集器不对内粗空间进行压缩、整理,所以运行一段时间会产生“碎片”,使得运行效率低。此值设置运行多少次GC以后对内训空间进行压缩、整理。

五、G1垃圾收集器

你可能感兴趣的:(java)