Java e.printStackTrace()案例講解
catch(Exception e) {e.printStackTrace();}當try語句中出現(xiàn)異常是時,會執(zhí)行catch中的語句,java運行時系統(tǒng)會自動將catch括號中的Exception e 初始化,也就是實例化Exception類型的對象。e是此對象引用名稱。然后e(引用)會自動調(diào)用Exception類中指定的方法,也就出現(xiàn)了e.printStackTrace() ;printStackTrace()方法的意思是:在命令行打印異常信息在程序中出錯的位置及原因。
二、不建議使用 e.printStackTrace()e.printStackTrace() 會導致鎖死?這僅僅是打印啊,怎么可能?!
先別驚呼不可能,且聽我細細道來。
注意右下角區(qū)域,紅框部分。這塊內(nèi)存是什么呢?非堆!那么,左邊是代碼緩存區(qū)內(nèi)存,右邊紅框就是字符串池,常量,基本類型數(shù)據(jù)的內(nèi)存區(qū)。然后呢?已經(jīng)滿了。什么原因呢?e.printStackTrace()!
滿了的后果呢?整個web服務,訪問之后,沒響應了,就當是卡死掉了。
看看有多少web的請求線程,被卡住在打印這一步!原因呢?要打印字符串輸出到控制臺上,那你字符串常量池所在的內(nèi)存塊要有空間啊。然而,因為e.printStackTrace() 語句要產(chǎn)生的字符串記錄的是堆棧信息,太長太多,內(nèi)存被填滿了!注意 上面代碼語句:4208行!
沒毛病,沒沒事兒找事兒冤枉誰。就是這句代碼惹的禍!當然,我承認,被 try 住的代碼本身就有問題,導致很多調(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)存,鎖死了,整個應用掛掉了。
綜上,這就是 e.printStackTrace() 引發(fā)的血案。
總結(jié):
代碼質(zhì)量啊親,代碼不拋異常咱不就能愉快的繼續(xù)浪么? 不要使用 e.printStackTrace() ,這玩意,在項目發(fā)布后,除過不斷的刷控制臺,并沒用什么卵用啊,建議使用logger輸出到日志文件里面啊。 推及開來,在java中,會產(chǎn)生大量字符串的方法,使用時,一定得悠著點,別一不小心撐到肚子(字符串池所屬的那么點非堆內(nèi)存空間),撐到肚子了,會死的啊 。三、建議使用 logger.error();logger.error('***', e);
建議使用logger輸出到日志文件里面。
到此這篇關(guān)于Java e.printStackTrace()案例講解的文章就介紹到這了,更多相關(guān)Java e.printStackTrace()內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Python獲取抖音關(guān)注列表封號賬號的實現(xiàn)代碼2. ajax請求添加自定義header參數(shù)代碼3. Python數(shù)據(jù)分析之pandas函數(shù)詳解4. 解決Python 進程池Pool中一些坑5. php測試程序運行速度和頁面執(zhí)行速度的代碼6. 無線標記語言(WML)基礎之WMLScript 基礎第1/2頁7. 三個不常見的 HTML5 實用新特性簡介8. 使用.net core 自帶DI框架實現(xiàn)延遲加載功能9. php網(wǎng)絡安全中命令執(zhí)行漏洞的產(chǎn)生及本質(zhì)探究10. Warning: require(): open_basedir restriction in effect,目錄配置open_basedir報錯問題分析
