【后端秘籍】【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 中已被废弃,不推荐使用。

相关推荐
长臂人猿5 小时前
JVM常用工具:jstat、jmap、jstack
linux·运维·jvm
柠檬味的薄荷心5 小时前
【C#补全计划】多线程
jvm
啊阿狸不会拉杆6 小时前
《算法导论》第 27 章 - 多线程算法
java·jvm·c++·算法·图论
稚辉君.MCA_P8_Java12 小时前
豆包 Java的23种设计模式
java·linux·jvm·设计模式·kubernetes
CCCC13101631 天前
嵌入式学习(day 28)线程
jvm·学习
没有bug.的程序员1 天前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
舒一笑1 天前
Started TttttApplication in 0.257 seconds (没有 Web 依赖导致 JVM 正常退出)
jvm·spring boot·后端
搬砖的小熊猫1 天前
JVM核心原理与实战优化指南
jvm
静若繁花_jingjing1 天前
JVM执行引擎深入理解
jvm
CHEN5_022 天前
【Java虚拟机】垃圾回收机制
java·开发语言·jvm