Java垃圾回收-栈和堆部分知识

数据共享的有栈、寄存器、PC,线程共享的有:堆、全局变量、静态变量、方法区。

代码逻辑,简单变量,结构体都是放入栈中,而对象,以及被装箱的数据是放入堆中的。回收的是堆内存。

对于年轻代,刚开始创建的对象都是放置在eden区的,而将年轻代分成3个部分,主要是为了生命周期短的对象尽量留在年轻代。当eden区申请不到空间的时候,进行minorGC,把存活的对象拷贝到survior。年老代主要存放生命周期比较长的对象,比如缓存对象。具体jvm内存回收过程描述如下:
1、对象在Eden区完成内存分配;
2、当Eden区满了,再创建对象,会因为申请不到空间,触发minorGC,进行young(eden+1survivor)区的垃圾回收;
3、minorGC时,Eden不能被回收的对象被放入到空的survivor(Eden肯定会被清空),另一个survivor里不能被GC回收的对象也会被放入这个survivor,始终保证一个survivor是空的;
4、当做第3步的时候,如果发现survivor满了,将这些对象copy到old区,或者survivor并没有满,但是有些对象已经足够Old,也被放入Old区 XX:MaxTenuringThreshold;
5、当Old区被放满的之后,进行fullGC;
当Java进行gc的时候,java除gc以外的其余进程会因为需要gc而暂停进行,发生stop-the-world,此时只剩下gc线程运行。

因此优化gc的时候主要是减少stop-the-world的发生。

posted on 2021-02-21 17:19  Halone  阅读(262)  评论(0编辑  收藏  举报