垃圾回收算法:
①引用计数算法:每一块对象内存都保存了一个计数器,用来记录当前对象被引用的次数,引用计数算法就是当计数器的值为0的时候就说明当前内存是没有被任何对象所引用的,那么就可以被回收了,但是引用计数算法存在的最大问题是无法解决循环依赖的问题,比如A引用了B,而B也引用了A,那么它们的计数器始终都不会为0,但它们整体上是没有被外部引用的,因而应该是需要被回收的;
②复制算法:复制算法将内存区域分为两部分,每次只使用其中一部分,当被使用的一部分占满了之后就对其进行回收,将其中还存活的对象转移到另一部分中,并且将原来那一部分完全清除即可,复制算法的优点在于如果每次复制时存活的对象比较少,那么其效率较高,如果存活的对象比较多,那么效率就比较低;
③标记清除算法:标记清除算法主要分为两阶段,标记阶段和清除阶段,在标记阶段,Java虚拟机会将当前内存区域中所有还存活的对象进行标记,清除阶段则是将未被标记的对象进行清除,标记清除算法的缺点是清除对象之后还存活的对象在内存中各处都有分布,这会导致产生很多内存碎片,而不利于后续大对象的分配;
④标记压缩算法:标记压缩算法基本步骤与标记清除算法类似,只是其多了一个压缩阶段,就是在清除之后,将还存活的对象统一移动到内存区域的起始位置,移动完成之后剩下的位置就都是可用的;
⑤分代算法:分代算法的基本思想是根据对象的特点将内存区域分为新生代和老年代两个区域,新生代的对象存活时间较短,老年代的对象存活时间较长,这样就可以根据其特点在新生代和老年代分别使用不同的垃圾回收算法,比如Java虚拟机在新生代使用复制算法,老年代使用的标记压缩算法;
⑥分区算法:分区算法的基本思想是将内存区域分为多个区,每次进行垃圾回收时可以只回收其中几个区域,而另外的区域则可正常使用,这种算法的优点在于在进行垃圾回收的时候能够大幅度的减少虚拟机的停顿时间。
垃圾回收器:①Serial垃圾回收器:串行回收器主要是指由一个单线程使用复制算法进行垃圾回收;
②ParNew回收器:ParNew GC主要是将串行的垃圾回收修改为了并行的;
③ParallelGC:Parallel GC是一个关注吞吐量的垃圾回收器,它有两个参数,主要作用是设置每次垃圾回收的最大停顿时间和设置垃圾回收时间所占用的总运行时间的比例;
④ParallelOldGC:ParallelOldGC与ParallelGC一样,是一个关注吞吐量的垃圾回收器,不过它主要用于老年代的GC;
⑤CMS:CMS垃圾回收器是一个老年代的并行回收器,它主要使用的是标记清除算法来进行老年代的垃圾回收;
⑥G1GC:G1GC也是一个并行垃圾回收器,它主要使用的是分区算法进行垃圾回收。
双亲委派模型:启动类加载器主要加载系统的核心类,扩展类加载器主要加载jre的ext目录下的类,应用程序类加载器则是加载运行的应用程序中的类。双亲委派模型就是这三个加载器以组合的方式进行自顶而下的类加载,比如在加载一个类的时候,首先是通过启动类加载器加载,如果启动类加载器中没有,则通过扩展类加载器进行加载,如果扩展类加载器中没有,则通过应用程序类加载器加载。