1、发现问题
接口调用的时候, 在使用list的addAll方法时, 报了UnsupportedOperationException错误. 如图所示:
2、排查
placementIdList 集合 和 a集合中的值都是正常的, 但是将a添加入placementIdList却报了UnsupportedOperationException.
经过排查发现在对placementIdList赋值的时候, 使用了Arrays.asList, 将数组转换成集合操作. 而Arrays.asList出来的ArrayList是Arrays自定义的,它没有完全实现List的方法,只是集成了AbstractList<E>,其与我们熟知的通用的ArrayList类不同, ArrayList类是直接实现了List 接口,实现了List所有方法。
所以Arrays.ArrayList是一个定长集合,可以使用set方法。但是因为它没有重写add,remove方法,所以一旦初始化元素后,集合的size就是不可变的。由于asList产生的集合并没有重写add,remove等方法,所以它会调用父类AbstractList的方法,而父类的方法中抛出的却是异常信息UnsupportedOperationException , UnsupportedOperation指的是不支持的操作 . 以后再遇到此类错误, 首先考虑是否是因为对使用Arrayt.asList生成的集合进行伸缩操作引起的.
总之,Arrays.asList 返回的 List 是一个不可变长度的列表,此列表不再具备原 List 的很多特性,因此慎用 Arrays.asList 方法。
另外, 在使用com.google.common.collect提供的jar包Lists类的Lists.newArrayList方法时,有相同的问题,如果传入基本类型数组,也无法转化成一个正常的List,这一点跟ArrayList结果是一致的。但是对象数组进行转化时,有一点不同,转成的List是支持add和remove操作的。
其实使用了Arrays.asList 或者 Lists.newArrayList生成了定长的list后,可以将其变为普通ArrayList:
List<String> commonArrayList = new ArrayList<>(Arrays.asList("a","b","c"));
.