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

相关推荐
Tony Bai2 小时前
Go 安全新提案:runtime/secret 能否终结密钥残留的噩梦?
java·开发语言·jvm·安全·golang
不会代码的小猴11 小时前
C++的第十一天笔记
java·前端·jvm
Unstoppable2211 小时前
八股训练营第 38 天 | 类加载机制介绍一下?介绍一下双亲委派机制?说一说你对 Spring AOP 的了解?说一说你对 Spring 中 IoC 的理解?
java·jvm·spring
博语小屋11 小时前
线程同步与条件变量
linux·jvm·数据结构·c++
javadaydayup14 小时前
Pagehelper触发 JVM 类校验失败,Idea 却因 -noverify 藏了雷
jvm
没有bug.的程序员2 天前
Async Profiler:最精准的火焰图工具
java·jvm·spring·对象分配·async profiler
小帅学编程2 天前
JVM学习记录
jvm·学习
Yweir2 天前
Linux性能监控的工具集和分析命令工具
java·linux·jvm
友莘居士2 天前
深入浅出:以太坊虚拟机(EVM)存储模型设计与权衡
jvm·区块链·虚拟机·solidity·evm·合约调用