【后端秘籍】【JVM篇】第一章

过去一年,工作忙碌,博客成了被遗忘的角落。时间飞逝,我决定重拾这段旅程,重新在这里记录我的思考与成长。

还是那句话,学起来:基础不牢,地动山摇。
写博客不仅是分享,更是与大家的连接。我希望通过这条渠道,找回那份灵感与激情。未来的日子,我会用心去记录,期待与每一位读者共同成长。关注我吧!

1.JVM的垃圾收集器有哪几种

JVM 主要有以下几种垃圾收集器:

Serial 收集器:单线程收集器,适用于单核处理器,简单且效率高。

ParNew 收集器:Serial的多线程版本,提升了新生代垃圾收集的效率。

Parallel 收集器:重视系统吞吐量,通过多线程并行处理垃圾收集,适合需要高吞吐量的场景。

CMS 收集器:旨在减少回收停顿时间,适合对延迟敏感的应用,使用并发收集方式。

G1 收集器:适用于大内存环境,能高效管理内存并优化回收停顿时间,逐步替代CMS。

2.类加载器的双亲委派模型

双亲委派模型确保类的加载顺序。加载时,类加载器会首先请求其父类加载器加载,如果父类加载器无法加载,再由子类加载器进行加载。这种机制可以避免类的重复加载和冲突。

3.JVM内存模型

JVM内存模型将堆内存分为新生代(Eden 区和Survivor 区)和老年代:

  • Eden 区:存放新生成的对象。
  • Survivor 区:包括 From 和 To 两个区域,存活对象在新生代中进行转移。
  • Tenured 区:老年代,存放长生命周期的对象。

4.新生代与老年代的垃圾收集策略

新生代:通常采用复制算法,因对象存活率低,回收速度快。

老年代:多采用标记-整理或标记-清除策略,因对象存活率高,减少内存碎片化。

5.方法区的作用

方法区用于存储类信息、常量、静态变量等,是各线程共享的数据区域。其设计目的是保证类数据唯一,节省内存,并确保数据的安全访问。

6.Full GC的触发条件

Full GC可能在以下情况下触发:

  • 老年代或方法区空间不足
  • 显式调用 System.gc()
  • JNI引用的情况下调用 System.gc()

7.Minor GC与Full GC的区别

Minor GC:发生在新生代,回收速度快,频繁触发。

Full GC:清理整个 Java 堆和方法区,速度较慢,影响较大。

8.栈内存溢出的情况

栈内存溢出主要发生在以下情况:

线程请求的栈深度超过 JVM 限制,抛出 StackOverflowError。

虚拟机栈动态扩展时无法分配足够内存,抛出 OutOfMemoryError。

9.Java内存模型(JMM)

Java 内存模型定义了共享内存中变量的访问规则,确保在多线程环境下,线程之间的互斥和可见性。它保证了一个线程对变量的修改对其他线程是可见的,避免数据不一致问题。

10.对象的finalize()方法

finalize() 方法在对象被垃圾回收器标记准备回收之前调用,用于资源释放。然而,因其调用时机不确定且在 JDK 9 中已被废弃,不推荐使用。

相关推荐
琪露诺大湿1 小时前
JavaEE-多线程初阶(1)
java·linux·开发语言·jvm·数据库·java-ee·1024程序员节
威哥爱编程3 小时前
Java Z 垃圾收集器如何彻底改变内存管理
java·jvm·zgc
与海boy6 小时前
第七章 JVM对高效并发的支持
jvm
王佑辉6 小时前
【jvm】如何设置堆内存大小
jvm
MegaDataFlowers16 小时前
JDK、JRE、JVM之间的关系
java·开发语言·jvm
程序员阿鹏16 小时前
详解:单例模式中的饿汉式和懒汉式
java·开发语言·jvm·后端·单例模式·eclipse
梦城忆16 小时前
JVM基础(内存结构)
开发语言·jvm·python
AGi_19 小时前
Java基础-JVM
java·开发语言·jvm
生产队队长1 天前
JVM(HotSpot):GC之垃圾回收器的分类
jvm
NeilNiu1 天前
什么是JVM
jvm