错误传播 --try{}catch(e){console.log(e)}
生活随笔
收集整理的這篇文章主要介紹了
错误传播 --try{}catch(e){console.log(e)}
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1、如果代碼發生了錯誤,又沒有被try ... catch捕獲,那么,程序執行流程會跳轉到哪呢?
function getLength(s) {return s.length; }function printLength() {console.log(getLength('abc')); // 3console.log(getLength(null)); // Error! }printLength();2、 如果在一個函數內部發生了錯誤,它自身沒有捕獲,錯誤就會被拋到外層調用函數,
如果外層函數也沒有捕獲,該錯誤會一直沿著函數調用鏈向上拋出,直到被JavaScript引擎捕獲,代碼終止執行。
所以,我們不必在每一個函數內部捕獲錯誤,只需要在合適的地方來個統一捕獲,一網打盡:
function main(s) {console.log('BEGIN main()');try {foo(s);} catch (e) {console.log('出錯了:' + e);}console.log('END main()'); }function foo(s) {console.log('BEGIN foo()');bar(s);console.log('END foo()'); }function bar(s) {console.log('BEGIN bar()');console.log('length = ' + s.length);console.log('END bar()'); }main(null); BEGIN main() BEGIN foo() BEGIN bar() 出錯了:TypeError: Cannot read property 'length' of null END main()?
3、當bar()函數傳入參數null時,代碼會報錯,錯誤會向上拋給調用方foo()函數,foo()函數沒有try ... catch語句,所以錯誤繼續向上拋給調用方main()函數,main()函數有try ... catch語句,所以錯誤最終在main()函數被處理了。
至于在哪些地方捕獲錯誤比較合適,需要視情況而定。
轉載于:https://www.cnblogs.com/slightFly/p/11576820.html
總結
以上是生活随笔為你收集整理的错误传播 --try{}catch(e){console.log(e)}的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: vue项目中使用echarts实现词云
- 下一篇: 异步错误处理 -- 时机