Java 库 throw 了运行时异常怎么搞? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hqtc
V2EX    Java

Java 库 throw 了运行时异常怎么搞?

  •  
  •   hqtc 2017-10-28 15:26:42 +08:00 5246 次点击
    这是一个创建于 2911 天前的主题,其中的信息可能已经有所发展或是发生改变。

    项目中使用 sip-servlets-impl-2.0.0.FINAL.jar 出现卡死问题,检查了一下是由于抛出了一个异常没有捕获,问题是这个异常是 Runtime 的:

    使用的 jar 里面关键方法大致如下:

    org.mobicents.servlet.sip.message.SipServletRequestImpl#createResponse(int, java.lang.String, boolean){ try { ... if(xx) throw nw IllegalStateException("blala"); ... }catch (ParseException ex) { throw new IllegalArgumentException("Bad status code " + statusCode, ex); } } 

    然而现在,我能怎么办,必须对这两个运行时异常进行 try catch 了吗?

    14 条回复    2017-10-29 14:05:49 +08:00
    GuuJiang
        1
    GuuJiang  
       2017-10-28 15:49:40 +08:00 via iPhone
    为什么要强调“问题是这个异常是 Runtime 的”,莫非你以为运行时异常就不用 /不能捕获?
    hqtc
        2
    hqtc  
    OP
       2017-10-28 16:03:59 +08:00
    运行时异常不是不建议捕获处理的吗。。。
    觉得抛出运行时异常这个行为就很诡异啊,因为外部调用的时候不强制要求捕获处理,外部调用者根本不知道你里面到底抛了几个异常
    hqtc
        3
    hqtc  
    OP
       2017-10-28 16:04:11 +08:00
    @GuuJiang 运行时异常不是不建议捕获处理的吗。。。
    觉得抛出运行时异常这个行为就很诡异啊,因为外部调用的时候不强制要求捕获处理,外部调用者根本不知道你里面到底抛了几个异常
    hujianxin
        4
    hujianxin  
       2017-10-28 16:54:19 +08:00   4
    运行时异常,不建议捕获处理,而是建议避免发生运行时异常,出现运行时异常,说明你的输入肯定是不符合库作者的约定的,所以说,如果按照库的要求约定来写代码就不会发生了。

    举几个例子:

    1. 假如一个方法要求不能输入 null,但是他没法强制你不输入 null,但是可以在方法开头加上判断,如果输入时 null,则抛出运行时异常。

    2. java 迭代器运行过程中不允许修改集合内容,但是他没法强制你不修改,但是他在迭代的过程中会判断,如果你修改了,则抛出运行时异常。

    3. wait notify 必须用在 synchronized 块中,但是作者没法强制你每次都正确的使用,但是他会判断你的 wait 方法调用是否放入 synchronized 中,如果没有放入,那么会抛出运行时异常。

    所以运行时异常,时作者使得程序正常运行的一种约定,你如果不按约定来,那么他会就抛出运行时异常,你按照约定来,那么就没问题
    haozhang
        5
    haozhang  
       2017-10-28 17:27:59 +08:00 via iPhone
    异常除了运行时抛出还能在什么时候抛出?外面包一层 try catch。
    hqtc
        6
    hqtc  
    OP
       2017-10-28 17:55:33 +08:00
    @hujianxin 有道理额,所以感觉还是分析调用方法的数据和参数。。。但是尼玛是多线程的,程序运行了许久只在昨天出现了一下,也没记得是哪个线程给的数据不对。。。难搞
    sorra
        7
    sorra  
       2017-10-28 19:00:17 +08:00
    @hqtc 要不要 catch 的唯一标准是这个异常你要不要处理 /要不要 let it crash
    记录错误信息的最好方式是打个 log,打出 stack trace 和线程名 /请求编号、用户 id 等信息,越全越好
    hsuan
        8
    hsuan  
       2017-10-28 19:57:18 +08:00 via Android
    运行时异常还是不要 catch 的好,一般运行时异常表示出现了无法恢复的严重错误,你就算 catch 了也跑不下去。
    skydiver
        9
    skydiver  
       2017-10-28 20:06:08 +08:00 via Android
    要么是你写错了,直接改代码修正错误

    要么是库的 bug,给他们提 bug report
    skydiver
        10
    skydiver  
       2017-10-28 20:06:49 +08:00 via Android
    @skydiver 如果确定是库有问题,可以先捕获异常 workaround 一下
    zhx1991
        11
    zhx1991  
       2017-10-28 23:42:07 +08:00
    运行时异常当然要捕获

    很简单的例子, 比如接收到一个 json 串转换为自定义对象, 这个转换要是错误抛出的异常就是运行时异常

    至少捕获打个日志啊
    esmdxx1
        12
    esmdxx1  
       2017-10-29 09:48:15 +08:00 via iPhone
    @GuuJiang
    @hqtc
    @haozhang
    @skydiver
    @zhx1991
    你们不查百度,知道品牌和商标区别吗?
    shibingsw
        13
    shibingsw  
       2017-10-29 10:44:57 +08:00
    多半是你的代码有 bug。
    skydiver
        14
    skydiver  
       2017-10-29 14:05:49 +08:00 via Android
    @esmdxx1 串线了?
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     947 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 22:43 PVG 06:43 LAX 15:43 JFK 18:43
    Do have faith in what you're doing.
    ubao msn 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