背景
今天在使用本地缓存结合Collections.sort对内存中的共享对象做排序时掉进了坑里面,本文记录下
错误代码
简化的代码如下所示:
List<Entity> entitys = caffineCache.get();// 从本地缓存获取列表对象
Collections.sort(entitys)
这样的写法应该很多从缓存中获取数据时比较常见的写法,先从缓存中获取数据,然后根据数据的属性再排个序,这里在多线程操作时会有并发修改list的问题,
这个问题会导致java.util.ConcurrentModificationException: null错误的发生,修改的方法可以不对共享的对象进行排序,而是先克隆一个list对象在进行排序的方式解决,也可以在把list对象保存本地缓存之前先排序,这样利用caffine的单线程回源特性也可以解决问题