午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Java e.printStackTrace()案例講解

瀏覽:18日期:2023-12-04 13:28:32
一、含義

catch(Exception e) {e.printStackTrace();}當try語句中出現異常是時,會執行catch中的語句,java運行時系統會自動將catch括號中的Exception e 初始化,也就是實例化Exception類型的對象。e是此對象引用名稱。然后e(引用)會自動調用Exception類中指定的方法,也就出現了e.printStackTrace() ;printStackTrace()方法的意思是:在命令行打印異常信息在程序中出錯的位置及原因。

二、不建議使用 e.printStackTrace()

     e.printStackTrace() 會導致鎖死?這僅僅是打印啊,怎么可能?!

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

Java e.printStackTrace()案例講解

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

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

Java e.printStackTrace()案例講解

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

Java e.printStackTrace()案例講解

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

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

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

總結:

代碼質量啊親,代碼不拋異常咱不就能愉快的繼續浪么? 不要使用 e.printStackTrace() ,這玩意,在項目發布后,除過不斷的刷控制臺,并沒用什么卵用啊,建議使用logger輸出到日志文件里面啊。 推及開來,在java中,會產生大量字符串的方法,使用時,一定得悠著點,別一不小心撐到肚子(字符串池所屬的那么點非堆內存空間),撐到肚子了,會死的啊 。三、建議使用 logger.error();

         logger.error('***',  e);

         建議使用logger輸出到日志文件里面。

到此這篇關于Java e.printStackTrace()案例講解的文章就介紹到這了,更多相關Java e.printStackTrace()內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 国产亚洲精品精品精品 | 91久久精品一区二区三 | 卡一卡二av | 久久精品这里只有精品 | 中文字幕在线免费观看 | 成人免费大片黄在线播放 | 亚洲精品久久久久久久久 | 性视频在线 | 日本高清有码 | 欧美成在线 | 亚洲小视频在线观看 | 亚洲精品成 | 欧美日本一区二区三区 | 在线视频观看一区 | 黄色小视频免费在线观看 | 色综合天天色 | 日韩在线视频播放 | 久久一区精品 | 欧美综合网站 | 91精品久久久久久久久久久久 | 国产在线成人 | 中文字幕久久网 | 曰韩在线 | 风间由美一区 | 在线一二三区 | 黄色av网站免费看 | 国产精品美女www爽爽爽 | av中文资源在线 | av大片网站 | 九月丁香婷婷 | 亚洲天堂网在线观看 | 超碰成人av| 久久久三级| 自拍偷拍网址 | 免费成人黄色网址 | 牛牛av在线 | 成年人在线免费观看视频网站 | 久久视频在线 | 色妹子影院 | 永久免费看成人av的动态图 | 波多野结衣一区二区三区 |