溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中e.printStackTrace()為什么會導致鎖死

發(fā)布時間:2022-01-04 09:52:07 來源:億速云 閱讀:122 作者:小新 欄目:云計算

這篇文章主要介紹java中e.printStackTrace()為什么會導致鎖死,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!


e.printStackTrace() 會導致鎖死?

這僅僅是打印啊,怎么可能?!

先別驚呼不可能,且聽我細細道來。

先看截圖1:

java中e.printStackTrace()為什么會導致鎖死

注意右下角區(qū)域,紅框部分。這塊內存是什么呢?非堆!那么,左邊是代碼緩存區(qū)內存,右邊紅框就是字符串池,常量,基本類型數據的內存區(qū)。然后呢?已經滿了。

什么原因呢?

e.printStackTrace()!

滿了的后果呢?整個web服務,訪問之后,沒響應了,就當是卡死掉了。

再來看截圖2:

java中e.printStackTrace()為什么會導致鎖死

看看有多少web的請求線程,被卡住在打印這一步!原因呢?要打印字符串輸出到控制臺上,那你字符串常量池所在的內存塊要有空間啊。然而,因為e.printStackTrace() 語句要產生的字符串記錄的是堆棧信息,太長太多,內存被填滿了!

注意 上面代碼語句:4208行!

來看圖3:

java中e.printStackTrace()為什么會導致鎖死

沒毛病,沒沒事兒找事兒冤枉誰。就是這句代碼惹的禍!當然,我承認,被 try 住的代碼本身就有問題,導致很多調用都會拋異常。

那么,讓我們再來理理整個事件產生的經過:

短時間內大量請求訪問此接口 -> 代碼本身有問題,很多情況下拋異常  -> e.printStackTrace() 來打印異常到控制臺 -> 產生錯誤堆棧字符串到字符串池內存空間 -> 此內存空間一下子被占滿了 -> 開始在此內存空間產出字符串的線程還沒完全生產完整,就沒空間了 ->  大量線程產出字符串產出到一半,等在這兒(等有內存了繼續(xù)搞?。?> 相互等待,等內存,鎖死了,整個應用掛掉了。

綜上,這就是 e.printStackTrace()  引發(fā)的血案。

總結當然重要,有3點:

1、代碼質量啊親,代碼不拋異常咱不就能愉快的繼續(xù)浪么?

2、不要使用 e.printStackTrace() 啊,這玩意兒,在項目發(fā)布后,除過不斷的刷控制臺,并沒用什么卵用啊,您到是用 log 對象輸出到日志文件里面啊。

3、推及開來,在java中,會產生大量字符串的方法,使用時,一定得悠著點,別一不小心撐到肚子(字符串池所屬的那么點非堆內存空間),撐到肚子了,會死的啊 。

以上是“java中e.printStackTrace()為什么會導致鎖死”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI