程序猿阵线联盟-汇总各类技术干货技术干货编程一生

漫画:全面理解java.lang.IllegalArgument

2018-06-11  本文已影响29人  编程一生

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

报错日志:

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

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

所以解决方法就是:

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

再举个例子:

这段代码会报错:

从源码来看:

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

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

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

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

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

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

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

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

本期文章:

上一篇下一篇

猜你喜欢

热点阅读