這篇文章主要介紹java中e.printStackTrace()為什么會導(dǎo)致鎖死,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
在阿拉爾等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作定制網(wǎng)站制作,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,成都營銷網(wǎng)站建設(shè),外貿(mào)網(wǎng)站制作,阿拉爾網(wǎng)站建設(shè)費用合理。
e.printStackTrace() 會導(dǎo)致鎖死?
這僅僅是打印啊,怎么可能?!
先別驚呼不可能,且聽我細細道來。
先看截圖1:
注意右下角區(qū)域,紅框部分。這塊內(nèi)存是什么呢?非堆!那么,左邊是代碼緩存區(qū)內(nèi)存,右邊紅框就是字符串池,常量,基本類型數(shù)據(jù)的內(nèi)存區(qū)。然后呢?已經(jīng)滿了。
什么原因呢?
e.printStackTrace()!
滿了的后果呢?整個web服務(wù),訪問之后,沒響應(yīng)了,就當(dāng)是卡死掉了。
再來看截圖2:
看看有多少web的請求線程,被卡住在打印這一步!原因呢?要打印字符串輸出到控制臺上,那你字符串常量池所在的內(nèi)存塊要有空間啊。然而,因為e.printStackTrace() 語句要產(chǎn)生的字符串記錄的是堆棧信息,太長太多,內(nèi)存被填滿了!
注意 上面代碼語句:4208行!
來看圖3:
沒毛病,沒沒事兒找事兒冤枉誰。就是這句代碼惹的禍!當(dāng)然,我承認,被 try 住的代碼本身就有問題,導(dǎo)致很多調(diào)用都會拋異常。
那么,讓我們再來理理整個事件產(chǎn)生的經(jīng)過:
短時間內(nèi)大量請求訪問此接口 -> 代碼本身有問題,很多情況下拋異常 -> e.printStackTrace() 來打印異常到控制臺 -> 產(chǎn)生錯誤堆棧字符串到字符串池內(nèi)存空間 -> 此內(nèi)存空間一下子被占滿了 -> 開始在此內(nèi)存空間產(chǎn)出字符串的線程還沒完全生產(chǎn)完整,就沒空間了 -> 大量線程產(chǎn)出字符串產(chǎn)出到一半,等在這兒(等有內(nèi)存了繼續(xù)搞啊)-> 相互等待,等內(nèi)存,鎖死了,整個應(yīng)用掛掉了。
綜上,這就是 e.printStackTrace() 引發(fā)的血案。
總結(jié)當(dāng)然重要,有3點:
1、代碼質(zhì)量啊親,代碼不拋異常咱不就能愉快的繼續(xù)浪么?
2、不要使用 e.printStackTrace() 啊,這玩意兒,在項目發(fā)布后,除過不斷的刷控制臺,并沒用什么卵用啊,您到是用 log 對象輸出到日志文件里面啊。
3、推及開來,在java中,會產(chǎn)生大量字符串的方法,使用時,一定得悠著點,別一不小心撐到肚子(字符串池所屬的那么點非堆內(nèi)存空間),撐到肚子了,會死的啊 。
以上是“java中e.printStackTrace()為什么會導(dǎo)致鎖死”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享標(biāo)題:java中e.printStackTrace()為什么會導(dǎo)致鎖死
文章分享:http://aaarwkj.com/article18/goopgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)、虛擬主機、做網(wǎng)站、定制網(wǎng)站、網(wǎng)站內(nèi)鏈、用戶體驗
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)