You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cayenne.apache.org by "Donald Vrakking (JIRA)" <ji...@apache.org> on 2010/10/04 15:05:34 UTC

[jira] Commented: (CAY-1487) Access to ObjectStore.objectMap not thread safe when creating new object instance (and processing snaphot events)

    [ https://issues.apache.org/jira/browse/CAY-1487?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12917583#action_12917583 ] 

Donald Vrakking commented on CAY-1487:
--------------------------------------

Is there any followup on this?

> Access to ObjectStore.objectMap not thread safe when creating new object instance (and processing snaphot events)
> -----------------------------------------------------------------------------------------------------------------
>
>                 Key: CAY-1487
>                 URL: https://issues.apache.org/jira/browse/CAY-1487
>             Project: Cayenne
>          Issue Type: Bug
>          Components: Core Library
>    Affects Versions: 2.0 branch
>            Reporter: Donald Vrakking
>
> The method ObjectStore.registerNode(..) is not synchronized, while getNode(..) is. The objectMap can be accessed in a thread-unsafe way when a new object instance is created and when at the same time snapshotevents are processed.
> When creating the instance, the unsafe registerNode method is used. It will start looping in the objectMap when at the same time when an EventDispatch thread tries to acces the objectMap through getNode(). The dispatch threads will go in a WAIT state which eventually results in a completely frozen application.
> I noticed that in cayenne 3 the registerNode() method is synchronized. Can such a fix also be applied to a cayenne 2.0.5 release?

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.