美文网首页
异常处理

异常处理

作者: 嗨黄先生 | 来源:发表于2017-10-26 22:22 被阅读0次

    常见的异常分类

    运行环境的多样性导致的异常(浏览器)
    语法错误,代码错误
    异常最大的特征,就是一旦代码出现异常,后面的代码就不会再执行

    异常捕获

    捕获异常,使用try-cath语句

    try{
        //这里写可能出现异常的代码
    }catch(e){
        //这里的e就是捕获的异常对象
        //可以在这里写,出现异常后的处理代码
    }
    

    异常捕获语句执行的过程为:
    代码正常运行, 如果在try中出现了错误, try 里面出现错误的语句后面的代码都不再执行, 直接跳转到 catch 中

    catch中处理错误信息

    然后继续执行后面的代码

    如果 try 中没有出现错误, 那么不走 catch 直接执行后面的代码

    通过try-catch语句进行异常捕获之后,代码将会继续执行,而不会中断。
    注意:

    语法错误异常用try-catch语句无法捕获,因为在预解析阶段,语法错误会直接检测出来,而不会等到运行的时候才报错。
    try-catch在一般日常开发中基本用不到,但是如果要写框架什么的,用的会非常多。因为这个会让框架变得健壮

    抛出异常

    如何手动的抛出异常呢?
    案例:自己写的一个函数,需要一个参数,如果用户不传参数,此时想直接给用户抛出异常,就需要了解如何抛出异常。
    抛出异常使用throw关键字,语法如下:

    throw 异常对象;
    

    异常对象一般是用new Error("异常消息"), 也可以使用任意对象

    function test(para){
        if(para == undefined){
            throw new Error("请传递参数");
            //这里也可以使用自定义的对象
            throw {"id":1, msg:"参数未传递"};
        }
    }
    
    try{
        test();
    }catch(e){
        console.log(e);
    }
    

    异常的传递机制

    function f1(){
      f2();//f1称为调用者,或主调函数,f2称为调用者,或被掉函数
    }
    function f2 () {
        f3();
    }
    
    function f3() {
        throw new Error( 'error' );
    }
    f1();
    

    当在被调函数内发生异常的时候,异常会一级一级往上抛出。

    异常捕获语句的完整模式

    异常捕获语句的完整模式为try-catch-finally

    try{
      //可能出现错误的代码
    }catch ( e ) {
        //如果出现错误就执行
    } finally {
        //结束 try 这个代码块之前执行, 即最后执行
    }
    

    finally中的代码,不管有没有发生异常,都会执行。一般用在后端语言中,用来释放资源,JavaScript中很少会用到

    相关文章

      网友评论

          本文标题:异常处理

          本文链接:https://www.haomeiwen.com/subject/vbslpxtx.html