叙述一下常见的GC算法?
1. 标记清除算法:将所有需要回收的对象进行标记,标记结束以后对标记的对象进行回收,但是效率低,会造成大量碎片。2. 复制算法:复制算法将空间分为两部分,每次只使用一部分。当一块空间用完了,就将这块还存活的对象复制到另一块,将已使用的快全部清除,这样不会产生碎片,但会浪费一部分内存空间。在堆中的年轻代使用这个算法,因为年轻代的对象生命周期比较短。年轻代将内存分为一个eden,两个survivor,每次使用一个eden和一个survivor,回收的时候,将eden和survivor中的对象复制到另