经过一段时间的学习与实践,飞鸟已经可以独力解决一些问题。小鱼就让飞鸟讲述一些遇到的问题和解决过程。

 

报错日志:

 

这个产生的原因是我覆盖Collections.sort的Comparator方法的时候

 

Collections.sort在jdk1.7版本之后底层用的是TimSort,这个Sort类会有很严格的检验,检验其自反性、传递性、对称性。而上面的代码忽视了相等的情况,不满足对称性。

 

 

所以解决方法就是:

 

 

 

 

    IllegalArgumentException是非法参数异常,报这个异常说明传入的参数违反了一个方法要求的某些特性。比如咱们刚才看的问题里这个Comparator类作为sort方法的参数就违反了TimSort要求的对称性。

 

    再举个例子:

 

这段代码会报错:

 

从源码来看:

 

如果参数里出现了指定的patternChars之外的字符就会报错。

 

    发生IllegalArgumentException基本可以认定为程序Bug。Bug是避免的,应该在测试时发现。所以最重要的措施是完善测试用例,全分支覆盖,做好积累沉淀。

    

    如果真的在运行时发生此情况,那就要做好及时的监控报警,现场快照保存,尽量第一时间发现并解决。

 

    对内部异常咱们可以这么处理。那外部异常呢?比如使用的一个中间件,中间件有可能会版本升级出现不符合预期的情况。

 

    对于这种外部依赖,当发生问题的时候最好是不影响现有程序。方法比如启动时加载,如果发生问题,程序根本启动不起来。因为线上一般都不会只部署一台机器,一台机器发生问题启动不起来一般不会影响线上服务。这时候只要快速修复问题即可。

    

    如果必须运行时调用那就要尽量弱化依赖和控制依赖。具体可参考静儿在美团技术博客的文章《美团点评智能支付核心交易系统的可用性实践》

 

 

静儿的画画水平有点差 /(ㄒoㄒ)/~~

 

关注静儿公众号,不定期漫画技术推送~

本期文章:

原文链接地址是:

漫画:全面理解java.lang.IllegalArgumentException及其可用性设计

跑题时间:恭喜你,你赢了

posted on 2018-06-12 06:39  编程一生  阅读(29236)  评论(5编辑  收藏  举报