OutOfMemoryError能被catch(Exception)捕获吗?

背景

写了一个 Kafka 消费者程序,Kafka 集群中数据量过大时,消费线程无故退出了,日志打印了心跳 OOM 异常信息:

但是消费线程里面的 run 方法里面明明包含了 catch (Exception e) ,结尾信息没有打印异常,为什么呢?

异常类体系结构复习

原因很简单: java.lang.OutOfMemoryError 这个异常类的顶层父类并不是 Exception,而是 Error

顺带复习下 Java 的异常类体系图:

此图来自《网络》

解决办法

我知道那个消费者线程退出肯定跟 OOM 异常有关,但是最初想没明白它退出的原因。后来看了下这个异常类的继承关系,改成 catch Throwable 后线程退出之前果然打印了该异常。

java.lang.OutOfMemoryError:Java heap space 这个异常的解决办法是对 JVM 参数进行调整,将 -Xmx 值由现在的 1G 改为 4G,就解决了。

启示录

开发中的异常捕获通常只到 Exception 类型就中止了,这个线程退出的情况,引发了一个思考:跟 JVM 相关的异常有没有必要捕获呢?

JVM相关的异常通常指的是Java虚拟机(JVM)自身抛出的错误,比如OutOfMemoryError、StackOverflowError等。这些异常是JVM的一部分,通常是严重错误,它们在程序的正常流程中不应该被捕获处理。

如果你尝试捕获这些异常,比如使用try-catch块,你会得到一个编译错误,因为这些异常是Error类型的,而不是Exception类型。Error类型的异常通常表示严重问题,应该让程序自然终止,而不是尝试恢复。

我想的也是不能捕获,内存空间不足时,程序已经无法继续运行了,即使捕获了 OOM ,后面线程继续运行还是一样的问题,治标不治本!

相关推荐
小锋java123414 分钟前
分享一套锋哥原创的基于LangChain4j的RAG医疗健康知识智能问答系统(SpringBoot4+Vue3+Ollama)
java·人工智能
程序员晨曦32 分钟前
Java 并发修仙传:ThreadLocal 从“闭关修炼”到“走火入魔”的救赎之路
java·开发语言
AIGS00134 分钟前
探索向量空间JBoltAI:工业企业数智化升级的基础设施
java·人工智能·人工智能ai大模型应用
zhangjw341 小时前
第18篇:Java网络编程零基础详解,IP、端口、TCP、UDP、Socket通信、实战文件传输
java·网络·tcp/ip
我命由我123451 小时前
Java 开发 - Jar 包与 War 包
java·开发语言·java-ee·intellij-idea·jar·idea·intellij idea
Upsy-Daisy1 小时前
Hermes Agent 学习笔记 04:工具调用系统,让 Agent 从“会说”变成“会做”
java·笔记·学习
Volunteer Technology1 小时前
SpringSecurity请求流转的本质
java·spring
心之伊始1 小时前
Spring AI MCP Client 实战:让 Java 后端通过 stdio 调用本地工具服务
java·spring boot·agent·spring ai·mcp
plainGeekDev1 小时前
文件读写(Java IO)→ Kotlin 扩展函数
android·java·kotlin
Full Stack Developme1 小时前
AspectJ 详解
java·后端