万一其他人有类似的问题,我想我应该在这里发布我的问题和解决方案。
基本上,我的代码在Java7下运行良好,但一直在Java8中抛出一个ConcurrentModificationException。其结构基本上如下:
List<FormatData> formats = service.getFormat(type);
for (FormatData f : formats) {
/* Do stuff here */
}但是,“在这里做事情”部分最后调用了相同的service.getFormat(type)函数并返回相同的列表。但是,相同的函数查找列表,但也对列表进行排序。在Java7中,由于列表已经排序,所以它没有修改它。在Java8中,它将重新排序排序列表视为已被修改。
发布于 2015-02-14 21:09:22
我的解决方案是双重的,任何一个都会奏效。首先,我将排序从检索函数中移开,这样就不会浪费时间--而是将它移到加载函数中,它本来应该放在第一位的。其次,在一个使用较少但返回相同列表但排序不同的函数中,我刚刚创建了一个新列表,然后对其进行排序并返回:
result = new ArrayList(oldList);
Collections.sort(result, otherComparator);此外,在返回任何一方之前,我添加了以下内容,以确保不会在不抛出异常的情况下进行更多的修改:
result = (result==null) ? null : Collections.unmodifiableList(result);https://stackoverflow.com/questions/28520268
复制相似问题