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

相关推荐
lpruoyu1 天前
颜群JVM【05】强软弱虚引用
jvm
勤奋菲菲1 天前
使用Mybatis-Plus,以及sqlite的使用
jvm·sqlite·mybatis
稚辉君.MCA_P8_Java1 天前
JVM第二课:一文讲透运行时数据区
jvm·数据库·后端·容器
杨DaB2 天前
【JavaSE】JVM
java·jvm
code小毛孩2 天前
如何简单的并且又能大幅度降低任务队列的锁粒度、提高吞吐量?
java·jvm·数据库
用手手打人2 天前
JVM(九)-- 类的生命周期
jvm
深海呐2 天前
Android 编译速度优化:JVM堆内存扩充
android·jvm·jvm内存扩充·android 加快编译速度
哈基米喜欢哈哈哈2 天前
低版本的JVM遇到高版本的class字节码是否会报错
java·jvm
用手手打人2 天前
JVM(八)-- Class文件
jvm
235162 天前
【并发编程】详解volatile
java·开发语言·jvm·分布式·后端·并发编程·原理