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

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

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


1112728-20180622234829995-139676886.png


报错日志:


1112728-20180622234845256-607315851.png


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


1112728-20180622234859651-1403421999.png


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


1112728-20180622234916250-915413563.png


所以解决方法就是:


1112728-20180622234931930-714339011.png


1112728-20180622234943841-648363134.png

1112728-20180622235010902-2008952511.png


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


再举个例子:


1112728-20180622235057550-1624757153.png


这段代码会报错:


1112728-20180622235108315-1546637534.png


从源码来看:


1112728-20180622235122671-1750218168.png


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


1112728-20180622235158678-1596558747.png


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

   

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

 

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

 

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

   

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


1112728-20180622235214144-800457835.png

相关文章
|
6天前
|
Java 程序员 编译器
|
6天前
|
存储 Java 数据库连接
Java中文异常——全解
Java中文异常——全解
21 0
|
7月前
|
Java
最全最详细最高质量 java 面试题
最全最详细最高质量 java 面试题
|
9月前
java202303java学习笔记第四十四天函数-使用规则-设计原则
java202303java学习笔记第四十四天函数-使用规则-设计原则
33 0
|
12月前
java202303java学习笔记第三十四天异常体系介绍1
java202303java学习笔记第三十四天异常体系介绍1
36 0
|
12月前
java202303java学习笔记第三十九天综合练习多线程的比较2
java202303java学习笔记第三十九天综合练习多线程的比较2
36 0
|
12月前
java202303java学习笔记第三十九天综合练习多线程的比较1
java202303java学习笔记第三十九天综合练习多线程的比较1
37 0
|
12月前
java202303java学习笔记第三十四天try...catch疑问2
java202303java学习笔记第三十四天try...catch疑问2
31 0
|
12月前
java202303java学习笔记第三十四天try...catch疑问1
java202303java学习笔记第三十四天try...catch疑问1
33 0
|
12月前
java202303java学习笔记第三十四天综合练习2
java202303java学习笔记第三十四天综合练习2
41 0