溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

java中e.printStackTrace()會(huì)不會(huì)輸出到控制臺(tái)

發(fā)布時(shí)間:2021-09-23 09:20:04 來(lái)源:億速云 閱讀:229 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹java中e.printStackTrace()會(huì)不會(huì)輸出到控制臺(tái),文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

  java中e.printStackTrace()只會(huì)輸出到控制臺(tái)嗎?不會(huì)輸出到日志文件嗎?要想輸出到日志文件是否需要logger.error(e)?需要logger.error(e)還是logger.error(e.printStackTrace())?

  e.printStackTrace()只會(huì)輸出到控制臺(tái)嗎

  tomcat下會(huì)輸出到catalina.out

  不要用e.pringStackTrace()打日志

  如果要輸入調(diào)用棧的話(huà),log.error("錯(cuò)誤信息",e);,不輸出調(diào)用棧的話(huà)就log.error("錯(cuò)誤信息");

  忽然笑

  e.pringStackTrace()底層是調(diào)用了System.err.println().應(yīng)該這樣用

  try{

  //doSomething

  }catch(IllegalAccessExceptione){

  logger.error("錯(cuò)誤信息:",e);

  }

  e.printStackTrace()會(huì)導(dǎo)致鎖死?

  注意右下角區(qū)域,紅框部分。這塊內(nèi)存是什么呢?非堆!那么,左邊是代碼緩存區(qū)內(nèi)存,右邊紅框就是字符串池,常量,基本類(lèi)型數(shù)據(jù)的內(nèi)存區(qū)。然后呢?已經(jīng)滿(mǎn)了。什么原因呢?e.printStackTrace()!

  滿(mǎn)了的后果呢?整個(gè)web服務(wù),訪(fǎng)問(wèn)之后,沒(méi)響應(yīng)了,就當(dāng)是卡死掉了。

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

  來(lái)看圖3:

  沒(méi)毛病,沒(méi)沒(méi)事兒找事兒冤枉誰(shuí)。就是這句代碼惹的禍!當(dāng)然,我承認(rèn),被try住的代碼本身就有問(wèn)題,導(dǎo)致很多調(diào)用都會(huì)拋異常。

  那么,讓我們?cè)賮?lái)理理整個(gè)事件產(chǎn)生的經(jīng)過(guò):

  短時(shí)間內(nèi)大量請(qǐng)求訪(fǎng)問(wèn)此接口->代碼本身有問(wèn)題,很多情況下拋異常->e.printStackTrace()來(lái)打印異常到控制臺(tái)->產(chǎn)生錯(cuò)誤堆棧字符串到字符串池內(nèi)存空間->此內(nèi)存空間一下子被占滿(mǎn)了->開(kāi)始在此內(nèi)存空間產(chǎn)出字符串的線(xiàn)程還沒(méi)完全生產(chǎn)完整,就沒(méi)空間了->大量線(xiàn)程產(chǎn)出字符串產(chǎn)出到一半,等在這兒(等有內(nèi)存了繼續(xù)搞?。?>相互等待,等內(nèi)存,鎖死了,整個(gè)應(yīng)用掛掉了。

以上是“java中e.printStackTrace()會(huì)不會(huì)輸出到控制臺(tái)”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI