这是堆栈跟踪:
java.lang.ArrayStoreException
at java.util.HashMap.transfer(Unknown Source)
at java.util.HashMap.resize(Unknown Source)
at java.util.HashMap.addEntry(Unknown Source)
at java.util.HashMap.put(Unknown Source)
at java.util.HashSet.add(Unknown Source)
一些观察:
- 这是一个间歇性问题
- JDK 1.6
- CentOS 5.3
据我所知,这个错误是间歇性的,我怀疑每当 HashSet(因此底层的 HashMap)需要调整自身大小时就会发生这种错误。但不确定为什么会出现此ArrayStoreException
。现在我想知道的是
-什么情况下会出现此错误?
最佳答案
我的猜测是您正在尝试同时从多个线程更新该集合。 HashSet
和 HashMap
并非设计为线程安全的 - 如果您要从多个线程访问您的集合,则应使用同步来防止并发访问。
当然,这只是一个猜测 - 如果没有看到您的代码,我无法判断您是否使用多个线程。不过,它会伴随着事物间歇性的一面......
关于java.util.Hashset 中的 java.lang.ArrayStoreException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7565137/