什么是垃圾
- 在运行程序中没有任何指针指向的对象,这个对象就是需要垃圾回收
- 如果不及时对内存的中垃圾进行清理,那么这些垃圾对象所占的内存空间会一直保留到应用程序结束,被保留的空间无法被其他对象使用。甚至可能导致内存溢出
为什么需要 GC
- 对于高级语言来说,一个基本认知是如果不进行垃圾回收,内存迟早都会被消耗完,因为不断地分配内存空间而不进行回收,就好像不停地生产生活垃圾而从来不打扫一样
- 除了释放没有用的对象,垃圾回收也可以清除内存里的记录碎片。碎片整理所占用的堆内存移动到堆一端,以便 JVM 将整理出的内存分配给新的对象
- 随着应用程序所对应的业务越来越大、复杂、用户越来越多,没有 GC 就不能保证应用程序的正常进行。而经常造成 STW 的 GC 又跟不上实际的需求,所以才会不断地尝试对 GC 进行优化
早期垃圾回收
- 在早期的 C / C++ 时代,垃圾回收基本上都是手工进行的,开发人员可以使用 new 关键字进行内存申请,并使用 delete 关键字进行内存释放。会给开发人员带来频繁申请和释放内存的管理负担。甚至造成内存泄漏
- 现在 Java, C#, Python, Ruby 都使用了自动垃圾回收的思想
Java 垃圾回收机制
- 自动内存管理,无需开发人员手动参与内存的分配和回收,这样降低了内存泄漏和内存溢出的风险
- 自动内存管理机制,将程序员从繁重的内存管理中释放出来,可以更专心的专注于业务开发
- 垃圾回收器可以对年轻代回收,也可以对老年代回收,甚至是全堆和方法区的回收,其中 Java 堆是垃圾收集器的工作重点
- 频繁收集Young区,较少收集Old区,基本不动 Perm区(或元空间)
担忧:
- 对于 Java 开发人员而言,自动内存管理就像是一个黑匣子,如果过度依赖于 "自动",那么这将会是一场灾难,最严重的就会弱化 Java 开发人员在程序出现内存溢出时定位问题和解决问题的能力
- 只有真正了解 JVM 是如何管理内存后,我们才能够在遇见OutOfMemoryError 时,快速地根据错误异常日志定位问题和解决问题
- 当需要排查各种内存溢出、内存泄漏问题时,当垃圾收集成为系统达到更高并发量的瓶颈时,我们就必须对这些"自动化"的技术实施必要的监控和调节