1、背景
该异常出现的原因是集合的参数发生了变更,一般是因为集合的长度发生了变化,大量出现在某天晚上的压测中。
2、原因
因为我在写新版功能的时候,我就将某个list直接从本地缓存的兜底中读取,没有new一个新的list,只是简单的引用。
开始以为这种操作没问题,因为也只对这个集合进行了读操作。但是没想到,对list进行分割的操作,也有可能会导致ConcurrentModificationException异常。
当本地缓存的定时任务更新了这个list时,而此时我又在对这个list进行分割操作,于是在高并发场景下大量报了ConcurrentModificationException。
3、解决方案
在从本地缓存中读取整个集合的数据时,最好要new一个本地对象来存储数据,不然很容易发送异常。