亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java e.printStackTrace()案例講解

 更新時(shí)間:2021年08月17日 11:06:31   作者:開(kāi)著奧迪賣小豬  
這篇文章主要介紹了Java e.printStackTrace()案例講解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

一、含義

catch(Exception e) {
e.printStackTrace();
}
當(dāng)try語(yǔ)句中出現(xiàn)異常是時(shí),會(huì)執(zhí)行catch中的語(yǔ)句,java運(yùn)行時(shí)系統(tǒng)會(huì)自動(dòng)將catch括號(hào)中的Exception e 初始化,也就是實(shí)例化Exception類型的對(duì)象。e是此對(duì)象引用名稱。然后e(引用)會(huì)自動(dòng)調(diào)用Exception類中指定的方法,也就出現(xiàn)了e.printStackTrace() ;
printStackTrace()方法的意思是:在命令行打印異常信息在程序中出錯(cuò)的位置及原因。

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

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

     先別驚呼不可能,且聽(tīng)我細(xì)細(xì)道來(lái)。

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

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

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

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

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

總結(jié):

  1. 代碼質(zhì)量啊親,代碼不拋異常咱不就能愉快的繼續(xù)浪么?
  2. 不要使用 e.printStackTrace() ,這玩意,在項(xiàng)目發(fā)布后,除過(guò)不斷的刷控制臺(tái),并沒(méi)用什么卵用啊,建議使用logger輸出到日志文件里面啊。
  3. 推及開(kāi)來(lái),在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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決使用httpclient傳遞json數(shù)據(jù)亂碼的問(wèn)題

    解決使用httpclient傳遞json數(shù)據(jù)亂碼的問(wèn)題

    這篇文章主要介紹了解決使用httpclient傳遞json數(shù)據(jù)亂碼的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • Spring Boot自定義Banner實(shí)現(xiàn)代碼

    Spring Boot自定義Banner實(shí)現(xiàn)代碼

    這篇文章主要介紹了Spring Boot自定義Banner實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • java中concat()方法的使用說(shuō)明

    java中concat()方法的使用說(shuō)明

    這篇文章主要介紹了java中concat()方法的使用說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • Java Spring MVC獲取請(qǐng)求數(shù)據(jù)詳解操作

    Java Spring MVC獲取請(qǐng)求數(shù)據(jù)詳解操作

    Spring MVC 是 Spring 提供的一個(gè)基于 MVC 設(shè)計(jì)模式的輕量級(jí) Web 開(kāi)發(fā)框架,本質(zhì)上相當(dāng)于 Servlet,Spring MVC 角色劃分清晰,分工明細(xì)。由于 Spring MVC 本身就是 Spring 框架的一部分,可以說(shuō)和 Spring 框架是無(wú)縫集成
    2021-11-11
  • Java AOP實(shí)現(xiàn)自定義滑動(dòng)窗口限流器方法詳解

    Java AOP實(shí)現(xiàn)自定義滑動(dòng)窗口限流器方法詳解

    這篇文章主要介紹了Java AOP實(shí)現(xiàn)自定義滑動(dòng)窗口限流器方法,其中滑動(dòng)窗口算法彌補(bǔ)了計(jì)數(shù)器算法的不足,滑動(dòng)窗口算法把間隔時(shí)間劃分成更小的粒度,當(dāng)更小粒度的時(shí)間間隔過(guò)去后,把過(guò)去的間隔請(qǐng)求數(shù)減掉,再補(bǔ)充一個(gè)空的時(shí)間間隔,需要的朋友可以參考下
    2022-07-07
  • Java多線程Condition接口原理介紹

    Java多線程Condition接口原理介紹

    這篇文章主要介紹了Java多線程Condition接口原理介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • 擴(kuò)展tk.mybatis的流式查詢功能實(shí)現(xiàn)

    擴(kuò)展tk.mybatis的流式查詢功能實(shí)現(xiàn)

    mybatis查詢默認(rèn)是一次獲取全部,如果數(shù)據(jù)過(guò)于龐大,就會(huì)導(dǎo)致OOM問(wèn)題,本文就介紹了tk.mybatis 流式查詢,具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-12-12
  • SpringBoot+@EnableScheduling使用定時(shí)器的常見(jiàn)案例

    SpringBoot+@EnableScheduling使用定時(shí)器的常見(jiàn)案例

    項(xiàng)目開(kāi)發(fā)中經(jīng)常需要執(zhí)行一些定時(shí)任務(wù),本文主要介紹了SpringBoot+@EnableScheduling使用定時(shí)器的常見(jiàn)案例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • RateLimit-使用guava來(lái)做接口限流代碼示例

    RateLimit-使用guava來(lái)做接口限流代碼示例

    這篇文章主要介紹了RateLimit-使用guava來(lái)做接口限流代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • JavaWeb實(shí)現(xiàn)文件的上傳與下載

    JavaWeb實(shí)現(xiàn)文件的上傳與下載

    這篇文章主要為大家詳細(xì)介紹了JavaWeb實(shí)現(xiàn)文件的上傳與下載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-04-04

最新評(píng)論