Java e.printStackTrace()案例講解
一、含義
catch(Exception e) {
e.printStackTrace();
}
當(dāng)try語句中出現(xiàn)異常是時(shí),會(huì)執(zhí)行catch中的語句,java運(yùn)行時(shí)系統(tǒng)會(huì)自動(dòng)將catch括號中的Exception e 初始化,也就是實(shí)例化Exception類型的對象。e是此對象引用名稱。然后e(引用)會(huì)自動(dòng)調(diào)用Exception類中指定的方法,也就出現(xiàn)了e.printStackTrace() ;
printStackTrace()方法的意思是:在命令行打印異常信息在程序中出錯(cuò)的位置及原因。
二、不建議使用 e.printStackTrace()
e.printStackTrace() 會(huì)導(dǎo)致鎖死?這僅僅是打印啊,怎么可能?!
先別驚呼不可能,且聽我細(xì)細(xì)道來。

注意右下角區(qū)域,紅框部分。這塊內(nèi)存是什么呢?非堆!那么,左邊是代碼緩存區(qū)內(nèi)存,右邊紅框就是字符串池,常量,基本類型數(shù)據(jù)的內(nèi)存區(qū)。然后呢?已經(jīng)滿了。什么原因呢?e.printStackTrace()!
滿了的后果呢?整個(gè)web服務(wù),訪問之后,沒響應(yīng)了,就當(dāng)是卡死掉了。

看看有多少web的請求線程,被卡住在打印這一步!原因呢?要打印字符串輸出到控制臺上,那你字符串常量池所在的內(nèi)存塊要有空間啊。然而,因?yàn)閑.printStackTrace() 語句要產(chǎn)生的字符串記錄的是堆棧信息,太長太多,內(nèi)存被填滿了!注意 上面代碼語句:4208行!

沒毛病,沒沒事兒找事兒冤枉誰。就是這句代碼惹的禍!當(dāng)然,我承認(rèn),被 try 住的代碼本身就有問題,導(dǎo)致很多調(diào)用都會(huì)拋異常。
那么,讓我們再來理理整個(gè)事件產(chǎn)生的經(jīng)過: 短時(shí)間內(nèi)大量請求訪問此接口 -> 代碼本身有問題,很多情況下拋異常 -> e.printStackTrace() 來打印異常到控制臺 -> 產(chǎn)生錯(cuò)誤堆棧字符串到字符串池內(nèi)存空間 -> 此內(nèi)存空間一下子被占滿了 -> 開始在此內(nèi)存空間產(chǎn)出字符串的線程還沒完全生產(chǎn)完整,就沒空間了 -> 大量線程產(chǎn)出字符串產(chǎn)出到一半,等在這兒(等有內(nèi)存了繼續(xù)搞?。?> 相互等待,等內(nèi)存,鎖死了,整個(gè)應(yīng)用掛掉了。
綜上,這就是 e.printStackTrace() 引發(fā)的血案。
總結(jié):
- 代碼質(zhì)量啊親,代碼不拋異常咱不就能愉快的繼續(xù)浪么?
- 不要使用 e.printStackTrace() ,這玩意,在項(xiàng)目發(fā)布后,除過不斷的刷控制臺,并沒用什么卵用啊,建議使用logger輸出到日志文件里面啊。
- 推及開來,在java中,會(huì)產(chǎn)生大量字符串的方法,使用時(shí),一定得悠著點(diǎn),別一不小心撐到肚子(字符串池所屬的那么點(diǎn)非堆內(nèi)存空間),撐到肚子了,會(huì)死的啊 。
三、建議使用 logger.error();
logger.error("***", e);
建議使用logger輸出到日志文件里面。
到此這篇關(guān)于Java e.printStackTrace()案例講解的文章就介紹到這了,更多相關(guān)Java e.printStackTrace()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決springMVC 跳轉(zhuǎn)js css圖片等靜態(tài)資源無法加載的問題
下面小編就為大家?guī)硪黄鉀QspringMVC 跳轉(zhuǎn)js css圖片等靜態(tài)資源無法加載的問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10
Spring-AOP @AspectJ切點(diǎn)函數(shù)之@annotation()用法
這篇文章主要介紹了Spring-AOP @AspectJ切點(diǎn)函數(shù)之@annotation()用法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
mybatis?<foreach>標(biāo)簽動(dòng)態(tài)增刪改查方式
這篇文章主要介紹了mybatis?<foreach>標(biāo)簽動(dòng)態(tài)增刪改查方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
Bean實(shí)例化之前修改BeanDefinition示例詳解
這篇文章主要為大家介紹了Bean實(shí)例化之前修改BeanDefinition示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
微信公眾號服務(wù)號推送模板消息設(shè)置方法(后端java)
公眾號時(shí)經(jīng)常會(huì)需要寫推送消息,從網(wǎng)上找了一大堆,都不是很全,所以這篇文章主要介紹了微信公眾號服務(wù)號推送模板消息設(shè)置方法的相關(guān)資料,需要的朋友可以參考下2023-02-02
SpringBoot 使用hibernate validator校驗(yàn)
這篇文章主要介紹了SpringBoot 使用hibernate validator校驗(yàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11
Java Morris遍歷算法及其在二叉樹中的應(yīng)用
Morris遍歷是一種基于線索二叉樹的遍歷算法,可以在不使用?;蜻f歸的情況下,實(shí)現(xiàn)二叉樹的前序、中序和后序遍歷。該算法利用二叉樹中的空指針或線索指針,將遍歷序列嵌入到原二叉樹中,實(shí)現(xiàn)了常數(shù)級別的空間復(fù)雜度,適用于對空間要求較高的場景2023-04-04
spring4.3 實(shí)現(xiàn)跨域CORS的方法
下面小編就為大家分享一篇spring4.3 實(shí)現(xiàn)跨域CORS的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01

