关于错误处理程序中【return】的用法

先让俺这位新人帮各位有幸游览到我博客文章的叔叔阿姨哥哥姐姐们解释一下什么是错误处理?即:当程序发生错误时,保证程序不会异常中断的机制。

那么为什么程序中会有错误处理呢?像我们通常无论是玩手机或者玩游戏的时候,可能在运行过程中,程序默认只要碰到错误就会闪退,这时候的用户体验极差!而这个错误处理程序中的(err)会在错误发生时,自动获得一个错误对象,在发生错误时,自动创建,来避免这个错误。

接下来俺要说的不是错误处理,而是returntry{}catch{}finally{}中的用法。  

 

首先,这是一个错误处理的基本流程: 

       try{

          可能发生错误的代码段

       }catch(err){

  如果发生错误,才执行的错误处理代码

       }finally{

  无论是否发生异常,都会执行的代码段

       }

      其实finally可省略。

让我们来看第一种最简单的return用法:(程序即不报错,而且finally部分没有return):

 关于错误处理程序中【return】的用法_第1张图片

 这时候,看后台输出的值是否和你们心中想的值是一样的呢?

其实在错误程序里,表达式只要被读到,就会将变量替换为值,在该题中,try{}里面的n++无论无何都是被读到的,在接下来的几题中这部分也都会被读到,因为try{}是这条程序的必经之路,n此时都会被+1,而catch{}这部分会被直接跳过(没有错误不执行),再到finally{}

再看第二种:(即在try{}中出现报错,而且finally部分没有return))

 关于错误处理程序中【return】的用法_第2张图片

这时候的console.logfun())返回的值是看return在哪家,ntry{}再到catch{}n变成了3,故第一个返回3,而无论无何,finally都是会被执行的!

接下来是第三种情况:(程序不报错,并且finally{}中有返回return存在的情况)

因为是不报错,所以程序直接跳过catch{}部分,这时候我们看到了两个return,这时候请注意:finally{}中的return会直接顶掉try{}中的return

 

最后一种情况:(既报错,finally{}又有return的情况)

 关于错误处理程序中【return】的用法_第3张图片

这种情况有两个变种,第一是在try{}中有报错,而且在最后finally{}中有return的返回值,

这种情况说复杂有点复杂,说简单有点简单,因为无论无何,finally有是要执行的,而且return也会顶掉上面的两个return

 

综上所述:我们可以的得出return在错误处理中的一般性结论:

1. finally中没有return

    如果不出错,首先会确定tryreturn的结果

      **再执行finally中的代码

                最后返回结果

                finally中的代码不会影响返回的结果

    如果出错,首先执行catch中的代码

              确定catchreturn的结果

            **再执行finally中的代码

              最后返回结果

                finally中的代码不会影响返回的结果

        2.finally中有returnfinally中的return会覆盖之前的所有return

 

如果您坚持看完了俺写的文章,这是我第一次写博客,有些激动也有些生疏,第一次知道写博客是可以插入代码的,早知道我就不通过截图来完成了。另外,这仅仅是本人在上课做笔记时的一些看法,一时心血来潮想要跟广大JS爱好者分享,为这个代码社区增贴点活力!这也可能仅仅是在将来去公司面试时可能会遇到的情况,我们都知道错误处理其实也可以用if(){}else{}代替,而且执行效率也会更高!谢谢!下次我一定再接再厉!

你可能感兴趣的:(关于错误处理程序中【return】的用法)