日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

美团面试题 | JVM 堆内存溢出后,其他线程是否可继续工作?

發(fā)布時(shí)間:2025/3/11 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 美团面试题 | JVM 堆内存溢出后,其他线程是否可继续工作? 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

作者:gosaintmrc

來源:http://sina.lt/gqaM

最近網(wǎng)上出現(xiàn)一個(gè)美團(tuán)面試題:“一個(gè)線程OOM后,其他線程還能運(yùn)行嗎?”

我看網(wǎng)上出現(xiàn)了很多不靠譜的答案。這道題其實(shí)很有難度,涉及的知識(shí)點(diǎn)有jvm內(nèi)存分配、作用域、gc等,不是簡(jiǎn)單的是與否的問題。

由于題目中給出的OOM,java中OOM又分很多類型;比如:堆溢出(“java.lang.OutOfMemoryError: Java heap space”)、永久帶溢出(“java.lang.OutOfMemoryError:Permgen space”)、不能創(chuàng)建線程(“java.lang.OutOfMemoryError:Unable to create new native thread”)等很多種情況。

本文主要是分析堆溢出對(duì)應(yīng)用帶來的影響。

先說一下答案,答案是還能運(yùn)行

代碼如下:

public class JvmThread {public static void main(String[] args) {new Thread(() -> {List<byte[]> list = new ArrayList<byte[]>();while (true) {System.out.println(new Date().toString() + Thread.currentThread() + "==");byte[] b = new byte[1024 * 1024 * 1];list.add(b);try {Thread.sleep(1000);} catch (Exception e) {e.printStackTrace();}}}).start();// 線程二new Thread(() -> {while (true) {System.out.println(new Date().toString() + Thread.currentThread() + "==");try {Thread.sleep(1000);} catch (Exception e) {e.printStackTrace();}}}).start();} }

結(jié)果展示:

Wed Nov 07 14:42:18 CST 2018Thread[Thread-1,5,main]== Wed Nov 07 14:42:18 CST 2018Thread[Thread-0,5,main]== Wed Nov 07 14:42:19 CST 2018Thread[Thread-1,5,main]== Wed Nov 07 14:42:19 CST 2018Thread[Thread-0,5,main]== Exception in thread "Thread-0" java.lang.OutOfMemoryError: Java heap space at com.gosaint.util.JvmThread.lambda$main$0(JvmThread.java:21) at com.gosaint.util.JvmThread$$Lambda$1/521645586.run(Unknown Source) at java.lang.Thread.run(Thread.java:748) Wed Nov 07 14:42:20 CST 2018Thread[Thread-1,5,main]== Wed Nov 07 14:42:21 CST 2018Thread[Thread-1,5,main]== Wed Nov 07 14:42:22 CST 2018Thread[Thread-1,5,main]==

JVM啟動(dòng)參數(shù)設(shè)置:

上圖是JVM堆空間的變化。我們仔細(xì)觀察一下在14:42:05~14:42:25之間曲線變化,你會(huì)發(fā)現(xiàn)使用堆的數(shù)量,突然間急劇下滑!這代表這一點(diǎn),當(dāng)一個(gè)線程拋出OOM異常后,它所占據(jù)的內(nèi)存資源會(huì)全部被釋放掉,從而不會(huì)影響其他線程的運(yùn)行!

講到這里大家應(yīng)該懂了,此題的答案為一個(gè)線程溢出后,進(jìn)程里的其他線程還能照常運(yùn)行。注意了,這個(gè)例子我只演示了堆溢出的情況。如果是棧溢出,結(jié)論也是一樣的,大家可自行通過代碼測(cè)試。

總結(jié)

其實(shí)發(fā)生OOM的線程一般情況下會(huì)死亡,也就是會(huì)被終結(jié)掉,該線程持有的對(duì)象占用的heap都會(huì)被gc了,釋放內(nèi)存。因?yàn)榘l(fā)生OOM之前要進(jìn)行g(shù)c,就算其他線程能夠正常工作,也會(huì)因?yàn)轭l繁gc產(chǎn)生較大的影響。

近期熱文

?
  • 面試珍藏:最常見的200多道Java面試題

  • 被一個(gè)熟悉的面試題問懵了:String...

  • 面試官:如何實(shí)現(xiàn)冪等性校驗(yàn)?

【END】

關(guān)注下方二維碼,訂閱更多精彩內(nèi)容

朕已閱?

總結(jié)

以上是生活随笔為你收集整理的美团面试题 | JVM 堆内存溢出后,其他线程是否可继续工作?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。