我已经扩展了hibernate提供的EmptyInterceptor
以在后刷新时执行一些逻辑。覆盖的后刷新方法提供了迭代器。当我尝试迭代时,我收到了ConcurrentModificationException
。
以下是我的代码段
@Override
public void postFlush(Iterator entities) throws CallbackException
{
while (entities.hasNext())
{
Object entity;
try
{
entity = entities.next();
}
catch(ConcurrentModificationException e)
{
// I get concurrent modification exception while iterating.
return;
}
}
}
我收到以下异常,
java.util.ConcurrentModificationException at java.util.HashMap $ HashIterator.nextEntry(HashMap.java:922) at java.util.HashMap $ ValueIterator.next(HashMap.java:950) 在org.hibernate.internal.util.collections.LazyIterator.next(LazyIterator.java:51) 在com.mycompany.MyInterceptor.postFlush(MyInterceptor.java:55) 在org.hibernate.event.internal.AbstractFlushingEventListener.postPostFlush(AbstractFlushingEventListener.java:401) at org.hibernate.event.internal.DefaultAutoFlushEventListener.onAutoFlush(DefaultAutoFlushEventListener.java:70) at org.hibernate.internal.SessionImpl.autoFlushIfRequired(SessionImpl.java:1130) 在org.hibernate.internal.SessionImpl.list(SessionImpl.java:1580) 在org.hibernate.internal.CriteriaImpl.list(CriteriaImpl.java:374)
从Hibernate Forum我们可以理解传递给postFlush()方法的迭代器不是线程安全的,导致ConcurrentModificationException。
赞赏避免异常的建议和解决方案。
答案 0 :(得分:0)
如果它的同步问题尝试使用ConcurrentHashMap
而不是普通的HashMap
另见this回答我认为这可能会有所帮助
答案 1 :(得分:0)
在List
@Override
public void postFlush(Iterator entities) {
super.postFlush(entities);
List<Object> objects = new ArrayList<>();
while (entities.hasNext()) {
objects.add(entities.next());
}
.
.
.
现在您可以使用objects
列表
答案 2 :(得分:-1)
在迭代之前通过org.apache.commons.collections.IteratorUtils将迭代器复制到列表中为我工作:
@Override
public void preFlush(Iterator entities) {
List list= IteratorUtils.toList(entities);
for(Object o : list){...}
}
但是我无法解释为什么它在使用IteratorUtils时起作用...