多层嵌套异常捕获/抛出的最佳实践? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a Javascript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
Javascript 权威指南第 5 版
Closure: The Definitive Guide
KirbySD
V2EX    Javascript

多层嵌套异常捕获/抛出的最佳实践?

  •  
  •   KirbySD 2021-11-19 00:22:23 +08:00 3069 次点击
    这是一个创建于 1422 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需求:多个方法一层一层嵌套,希望在各个方法出现异常时打断不必要的函数执行,进行异常处理并抛出给用户

    现在的实现:
    有调用链为 a() -> b() -> c() -> d() 的方法
    每层如果出现异常,将会往 class ErrorHandler 添加异常,并往外抛出
    抛出到 a() 时会使用调用 ErrorHandler 获取已记录的异常( d 抛出的记录为 d ,以此类推)并进行处理

    我的尝试:

    • 每个方法里直接简单粗暴地 try catch:不知道这个异常究竟是哪里抛出的( error 只有 type 和 message )
    • try catch 里抛出本层信息到 error 里继续抛出:高层的会覆盖底层的
    • 手动实现一个栈:感觉不是最佳实践?
    • try catch 里确认没有底层 error 信息才加入本层信息并抛出:感觉不如实现一个栈?

    想请教:这种设计的最佳实践是怎么样的? 是否尽量把调用拍扁更好?(但拍扁感觉无法有效复用)

    9 条回复    2021-11-19 12:03:11 +08:00
    dcsuibian
        1
    dcsuibian  
       2021-11-19 00:50:44 +08:00
    如果是我的话,异常只在最顶层处理,中间不做 try...catch...
    KirbySD
        2
    KirbySD  
    OP
       2021-11-19 01:16:41 +08:00 via iPhone
    @dcsuibian 中间不做 try catch 我也想过,但感觉和第一条尝试一样无法捕获出现异常的具体位置…
    yanguango
        3
    yanguango  
       2021-11-19 02:52:09 +08:00
    * 只在最外层 catch ,stacktrace 会有哪里 throw 的信息,不需要自己处理
    * 尽量使用 unchecked exception
    dustinth
        4
    dustinth  
       2021-11-19 07:51:34 +08:00
    异常有两个维度: 是否可纠错, 是否需感知.

    针对不同的层面(比如提供接口给上游或者外部), 这两个维度又是相对的, 比如 IO 错误, 如果让最终用户重试的话可以直接抛出 unchecked 错误, 如果让中间层重试的话则需要抛出 checked 错误; 中间层对于自己不能处理的错误是不需要感知的, 可以抛出 unchecked Exception, 然后包装给外部方可处理的情况下, 又可以把 unchecked 转为 checked Exception.

    当然为了方便可以统一用 unchecked, 感兴趣的中间层可以 catch 特定的 exception 做处理.

    至于 Exception 是否需要包装, 取决于系统怎么抽象自己的错误, 比如 IOException 和 NetworkException 或者有些 RuntimeException 对外部来说都是 InternalException.
    dustinth
        5
    dustinth  
       2021-11-19 07:54:48 +08:00
    @dustinth 看节点是 Javascript... 那关于 checked 那个讨论就不用了, 只需要关心在哪一层是否需要包装,是否需要处理了.
    dcsuibian
        6
    dcsuibian  
       2021-11-19 10:10:32 +08:00
    wancoco
        7
    wancoco  
       2021-11-19 10:21:06 +08:00
    加异常处理器集中处理是不是可以解决这个问题,只需要分场景判断是否需要加 try-catch ,对于二方、三方的接口就加上 try-catch ,其他引起的错误直接交给异常处理器去做
    wancoco
        8
    wancoco  
       2021-11-19 10:37:11 +08:00
    @wancoco 搞错辽,以为是 java 呢
    aguesuka
        9
    aguesuka  
       2021-11-19 12:03:11 +08:00
    js 的 Error 对象是有异常栈的, 也许你 ErrorHandler 没有继承 Error?
    https://developer.mozilla.org/en-US/docs/web/Javascript/reference/global_objects/error
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2643 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 14:03 PVG 22:03 LAX 07:03 JFK 10:03
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86