[
https://issues.apache.org/jira/browse/JCR-713?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Jukka Zitting updated JCR-713:
------------------------------
Affects Version/s: 1.2.1
> ConcurrentModificationException during registration of nodetypes
> ----------------------------------------------------------------
>
> Key: JCR-713
> URL: https://issues.apache.org/jira/browse/JCR-713
> Project: Jackrabbit
> Issue Type: Bug
> Components: core
> Affects Versions: 1.1.1, 1.2.1
> Reporter: Martijn Hendriks
> Assigned To: Stefan Guggisberg
> Fix For: 1.2.2
>
>
> During the registration of a set of nodetypes this exception may be
> encountered:
> java.util.ConcurrentModificationException
> at
> org.apache.commons.collections.map.AbstractReferenceMap$ReferenceEntrySetIterator.checkMod(AbstractReferenceMap.java:761)
> at
> org.apache.commons.collections.map.AbstractReferenceMap$ReferenceEntrySetIterator.hasNext(AbstractReferenceMap.java:735)
> at
> org.apache.jackrabbit.core.nodetype.NodeTypeRegistry.notifyRegistered(NodeTypeRegistry.java:1750)
> at
> org.apache.jackrabbit.core.nodetype.NodeTypeRegistry.registerNodeTypes(NodeTypeRegistry.java:223)
> It seems that the copying of the listeners triggered this exception:
> private void notifyRegistered(QName ntName) {
> // copy listeners to array to avoid ConcurrentModificationException
> NodeTypeRegistryListener[] la =
> new NodeTypeRegistryListener[listeners.size()];
> Iterator iter = listeners.values().iterator();
> int cnt = 0;
> 1750: while (iter.hasNext()) {
> la[cnt++] = (NodeTypeRegistryListener) iter.next();
> }
> for (int i = 0; i < la.length; i++) {
> if (la[i] != null) {
> la[i].nodeTypeRegistered(ntName);
> }
> }
> }
> The methods "notifyReRegistered" and "notifyUnregistered" will probably
> suffer from the same problem.
> Reproduction of this exception may be tricky; it only occurred once in our
> application. It is probably a race condition: another thread might access the
> listeners during the copy. It may be helpful to use a debugger and set a
> breakpoint in the middle of the copy giving other threads the opportunity to
> access the listeners...
> We think that a possible solution is the following:
> /**
> * Notify the listeners that a node type <code>ntName</code> has been
> registered.
> */
> private void notifyRegistered(QName ntName) {
> // copy listeners to array to avoid ConcurrentModificationException
> NodeTypeRegistryListener[] la;
> synchronized (listeners) {
> la = (NodeTypeRegistryListener[]) listeners.values().toArray(new
> NodeTypeRegistryListener[listeners.size()]);
> }
> for (int i = 0; i < la.length; i++) {
> if (la[i] != null) {
> la[i].nodeTypeRegistered(ntName);
> }
> }
> }
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.