一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

使用try-catch捕獲異常會影響性能嗎?

小林coding ? 來源:yes的練級攻略 ? 2023-04-01 11:08 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

“你看著這鬼代碼,竟然在 for 循環(huán)里面搞了個 try-catch,不知道try-catch有性能損耗嗎?”

老陳煞有其事地指著屏幕里的代碼:

for(inti=0;i

我探過頭去看了眼代碼,“那老陳你覺得該怎么改?”

“當然是把 try-catch 提到外面?。 崩详惸X子都不轉(zhuǎn)一下,脫口而出。

“你是不是傻?且不說性能,這代碼的目的明顯是讓循環(huán)內(nèi)部單次調(diào)用出錯不影響循環(huán)的運行,你其到外面業(yè)務(wù)邏輯不就變了嗎!”

老陳撓了撓他的地中海,“好像也是??!”

“回過頭來,catch 整個 for 循環(huán)和在循環(huán)內(nèi)部 catch,在不出錯的情況下,其實性能差不多?!?我喝一口咖啡不經(jīng)意地提到,準備在老陳前面秀一下。

“啥意思?”老陳有點懵地看著我,“try-catch是有性能損耗的,我可是看過網(wǎng)上資料的!”

果然,老陳上鉤了,我二話不說直接打開 idea,一頓操作敲了以下代碼:

publicclassTryCatchTest{

@Benchmark
publicvoidtryfor(Blackholeblackhole){
try{
for(inti=0;i

“BB 不如 show code,看到?jīng)],老陳,我把 try-catch 從 for 循環(huán)里面提出來跟在for循環(huán)里面做個對比跑一下,你猜猜兩個差多少?”

“切,肯定 tryfor 性能好,想都不用想,不是的話我倒立洗頭!”老陳信誓旦旦道。

我懶得跟他BB,直接開始了 benchmark,跑的結(jié)果如下:

600c01bc-bb5d-11ed-bfe3-dac502259ad0.png

可以看到,兩者的性能(數(shù)字越大越好)其實差不多:

fortry: 86,261(100359-14098) ~ 114,457(100359+14098)

tryfor: 95,961(103216-7255) ~ 110,471(103216+7255)

我再調(diào)小(一般業(yè)務(wù)場景 for 循環(huán)次數(shù)都不會很多)下 for 循環(huán)的次數(shù)為 1000 ,結(jié)果也是差不多:

6023335a-bb5d-11ed-bfe3-dac502259ad0.png

老陳一看傻了:“說好的性能影響呢?怎么沒了?”

我直接一個javap,讓老陳看看,其實兩個實現(xiàn)在字節(jié)碼層面沒啥區(qū)別:

tryfor 的字節(jié)碼

異常表記錄的是 0 - 20 行,如果這些行里面的代碼出現(xiàn)問題,直接跳到 23 行處理。

603a6c1e-bb5d-11ed-bfe3-dac502259ad0.png

fortry 的字節(jié)碼

差別也就是異常表的范圍小點,包的是 9-14 行,其它跟 tryfor 都差不多。

60bda0fc-bb5d-11ed-bfe3-dac502259ad0.png圖片

所以從字節(jié)碼層面來看,沒拋錯兩者的執(zhí)行效率其實沒啥差別。

“那為什么網(wǎng)上流傳著try-catch會有性能問題的說法???”老陳覺得非常奇怪。

這個說法確實有,在《Effective Java》這本書里就提到了 try-catch 性能問題:

61350138-bb5d-11ed-bfe3-dac502259ad0.png

并且還有下面一段話:

615dbf10-bb5d-11ed-bfe3-dac502259ad0.png圖片

正所謂聽話不能聽一半,以前讀書時候最怕的就是一知半解,因為完全理解選擇題能選對,完全不懂蒙可能蒙對,一知半解必定選到錯誤的選項!

《Effective Java》書中說的其實是不要用 try-catch 來代替正常的代碼,書中的舉例了正常的 for 循環(huán)肯定這樣實現(xiàn):

6196087a-bb5d-11ed-bfe3-dac502259ad0.png

但有個臥龍偏偏不這樣實現(xiàn),要通過 try-catch 拐著彎來實現(xiàn)循環(huán):

61a86c7c-bb5d-11ed-bfe3-dac502259ad0.png

這操作我只能說有點逆天,這兩個實現(xiàn)的對比就有性能損耗了。

我們直接再跑下有try-catch 的代碼和沒 try-catch的 for 循環(huán)區(qū)別,代碼如下:

6202e3e6-bb5d-11ed-bfe3-dac502259ad0.png

結(jié)果如下:

621415ee-bb5d-11ed-bfe3-dac502259ad0.png

+-差不多,直接看前面的分數(shù)對比,沒有 ry-catch 的性能確實好些,這也和書中說的 try-catch 會影響 JVM 一些特定的優(yōu)化說法吻合,但是具體沒有說影響哪些優(yōu)化,我猜測可能是指令重排之類的。

好了,我再總結(jié)下有關(guān) try-catch 性能問題說法

try-catch 相比較沒 try-catch,確實有一定的性能影響,但是旨在不推薦我們用 try-catch 來代替正常能不用 try-catch 的實現(xiàn),而不是不讓用 try-catch。

for循環(huán)內(nèi)用 try-catch 和用 try-catch 包裹整個 for 循環(huán)性能差不多,但是其實兩者本質(zhì)上是業(yè)務(wù)處理方式的不同,跟性能扯不上關(guān)系,關(guān)鍵看你的業(yè)務(wù)流程處理。

雖然知道try-catch會有性能影響,但是業(yè)務(wù)上不需要避諱其使用,業(yè)務(wù)實現(xiàn)優(yōu)先(只要不是書中舉例的那種逆天代碼就行),非特殊情況下性能都是其次,有意識地避免大范圍的try-catch,只 catch 需要的部分即可(沒把握全 catch 也行,代碼安全執(zhí)行第一)。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    2989

    瀏覽量

    109539
  • JVM
    JVM
    +關(guān)注

    關(guān)注

    0

    文章

    160

    瀏覽量

    12616

原文標題:支付寶二面:使用 try-catch 捕獲異常會影響性能嗎?大部分人都會答錯!

文章出處:【微信號:小林coding,微信公眾號:小林coding】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    普源DHO5104波形捕獲率對偶發(fā)故障診斷的影響

    一、偶發(fā)故障診斷的挑戰(zhàn)與波形捕獲率的核心價值 偶發(fā)故障(Intermittent Fault)具有隨機性強、持續(xù)時間短、復(fù)現(xiàn)概率低等特點,傳統(tǒng)示波器常因波形捕獲速率不足而難以捕捉到關(guān)鍵信號異常。例如
    的頭像 發(fā)表于 06-19 15:14 ?154次閱讀
    普源DHO5104波形<b class='flag-5'>捕獲</b>率對偶發(fā)故障診斷的影響

    泰克示波器高級觸發(fā)功能捕獲異常信號的5種方法

    在電子工程領(lǐng)域,示波器是調(diào)試和分析信號的核心工具,而泰克示波器憑借其強大的高級觸發(fā)功能,能夠精準捕獲異常信號,幫助工程師快速定位問題。本文將詳細介紹五種利用泰克示波器高級觸發(fā)功能捕獲異常
    的頭像 發(fā)表于 05-29 09:38 ?187次閱讀
    泰克示波器高級觸發(fā)功能<b class='flag-5'>捕獲</b><b class='flag-5'>異常</b>信號的5種方法

    HarmonyOS5云服務(wù)技術(shù)分享--云數(shù)據(jù)庫使用指南

    ?? ??性能優(yōu)化??: 避免頻繁小數(shù)據(jù)寫入,優(yōu)先批量操作。 復(fù)雜查詢盡量在服務(wù)端預(yù)過濾,減少數(shù)據(jù)傳輸量。 ??錯誤處理??: 所有操作建議包裹在try-catch中,捕獲異步異常。
    發(fā)表于 05-22 18:29

    HarmonyOS5云服務(wù)技術(shù)分享--ArkTS調(diào)用函數(shù)

    ); ?? 避坑指南: 文件參數(shù)建議使用JSON對象傳遞 大文件傳輸記得調(diào)整超時時間(默認70秒) 錯誤處理別忘記加try-catch塊 生產(chǎn)環(huán)境務(wù)必做好安全認證 ? 實戰(zhàn)技巧: 通過
    發(fā)表于 05-22 18:22

    HarmonyOS5云服務(wù)技術(shù)分享--退出登錄文檔問題

    (別只說「操作失敗」) 提供備選驗證方式 連續(xù)錯誤后鎖定要人性化(別永久封禁) 五、說點掏心窩的話 其實認證模塊最讓人頭疼的不是代碼,而是各種邊界情況處理。建議大家在開發(fā)時: 多用try-catch包裹
    發(fā)表于 05-22 17:01

    使用STM32捕獲PWM時同時捕獲2個通道時會出現(xiàn)捕獲的頻率值不準確的問題,是什么原因?qū)е碌模?/a>

    在使用STM32F103芯片的2個定時器捕獲2路PWM波時,當2路信號同時輸入時,會出現(xiàn)捕獲的頻率不準確,但是分開一路一路的輸入捕獲時,捕獲的PWM頻率是正確的,這是什么原因?qū)е碌哪兀?/div>
    發(fā)表于 04-25 08:29

    使用STM32捕獲PWM時同時捕獲2個通道時會出現(xiàn)捕獲的頻率值不準,為什么?

    在使用STM32F103芯片的2個定時器捕獲2路PWM波時,當2路信號同時輸入時,會出現(xiàn)捕獲的頻率不準確,但是分開一路一路的輸入捕獲時,捕獲的PWM頻率是正確的,這是什么原因?qū)е碌哪兀?/div>
    發(fā)表于 04-22 10:43

    泰克MDO3052示波器波形捕獲率評測

    泰克MDO3052作為中端混合域示波器的代表型號,其波形捕獲性能在同類產(chǎn)品中處于領(lǐng)先地位。本文將從技術(shù)原理、實測數(shù)據(jù)、應(yīng)用場景及局限性等多個維度,結(jié)合工程實踐案例,全面解析MDO3052的波形捕獲
    的頭像 發(fā)表于 04-02 11:49 ?363次閱讀
    泰克MDO3052示波器波形<b class='flag-5'>捕獲</b>率評測

    最新 HUAWEI DevEco Studio 調(diào)試技巧

    使用 console.table 來友好的進行輸出 try-catch 另外有一些程序可能在運行的時候會導(dǎo)致程序成直接崩潰,也沒有太多錯誤提示,這個時候我們可以使用 try-catch捕獲和輸出
    發(fā)表于 03-30 06:55

    示波器的性能術(shù)語(下)

    01示波器的性能術(shù)語-波形捕獲速率等波形捕獲速率所有示波器都會眨眼睛。也就是說,它們會每秒睜開眼睛多少次,來捕獲信號,其間則會閉上眼睛。這就是波形
    的頭像 發(fā)表于 03-17 11:40 ?542次閱讀
    示波器的<b class='flag-5'>性能</b>術(shù)語(下)

    ADS1291測試中經(jīng)常會出現(xiàn)R波變小的情況,為什么?

    最近使用ADS1291的過程中,剛開始非常順利,很快就能正確的采集到波形,噪聲情況良好,但是后面測試的時候發(fā)現(xiàn)了一個非常奇怪的問題,測試中經(jīng)常會出現(xiàn)R波變小的情況,或者R波根本就看不到,而P波、T
    發(fā)表于 01-09 06:39

    LM98640調(diào)試過程中發(fā)現(xiàn)時常會出現(xiàn)配置不正確的現(xiàn)象,怎么解決?

    我使用了一款TI公司的AD轉(zhuǎn)換芯片LM98640,但調(diào)試過程中發(fā)現(xiàn)時常會出現(xiàn)配置不正確的現(xiàn)象,反讀寄存器發(fā)現(xiàn),有問題的AD配置與正常的AD配置不一致,反復(fù)核對時序和供電情況,沒有發(fā)現(xiàn)異常,現(xiàn)在
    發(fā)表于 12-25 06:26

    在雙絞線線路上捕獲1394個事件

    電子發(fā)燒友網(wǎng)站提供《在雙絞線線路上捕獲1394個事件.pdf》資料免費下載
    發(fā)表于 09-29 09:41 ?0次下載
    在雙絞線線路上<b class='flag-5'>捕獲</b>1394個事件

    是德DSOX4032A示波器波形捕獲

    在電子工程領(lǐng)域,示波器是不可或缺的工具之一。而其中,是德DSOX4032A示波器以其卓越的性能和精準的測量能力備受青睞。今天,我們就來深入了解一下是德DSOX4032A示波器的波形捕獲率。 一、波形
    的頭像 發(fā)表于 08-30 15:38 ?581次閱讀
    是德DSOX4032A示波器波形<b class='flag-5'>捕獲</b>率

    HarmonyOS Next原生應(yīng)用開發(fā)-從TS到ArkTS的適配規(guī)則(十四)

    類型,應(yīng)省略類型標注。TypeScript try { // ... } catch (a: unknown) { // 處理異常 } ArkTS try { // ... }
    發(fā)表于 08-16 10:20