sebb <seb...@gmail.com> wrote on 06/10/2011 11:26:27 AM:

> On 9 June 2011 17:51, Newman, John W <newma...@d3onc.com> wrote:
> > Thanks Michael.  That?s the response I?ve been waiting for.  This whole
> > situation is really unfortunate, since it?s not even my code that is
missing
> > the required locking, and the developers of that faulting code have
pretty
> > decent justification for refusing to add it.  I?ll try to push back on
them
> > a little more for adding an extension since this the xerces dom is
really
> > the default.  I am not the only one affected by this, anyone using the
dom
> > package in that library without swapping the default implementation
will run
> > into this.  It?s just so rare and such a lucky situation that I?m
probably
> > the first to notice it.
> >
> >
> >
> > There?s really nothing I can do besides some sort of wrapper or proxy
> > solution, a massive document pool, OR a larger re-architecting effort
<- .
> > Maybe I can come up with something clean and quick, but without a
thread
> > dump at the instant when this situation occurs, I can?t get it under
test,
> > and can?t come up with the fix?
> >
> > I guess my question is, if there?s a simple answer to this, what
specific
> > methods of your library can cause volatility?  Is it just
NodeList.length()
> > and NodeList.item(), any specific others, or ALL of them?    Those two
are
> > always the ones I?ve already ran into and have syncs around where my
code is
> > using them, it wasn?t too hard to get some NPEs without the syncs.  But
> > without them I never noticed corrupt documents.
>
> Even if writes are only performed by a single thread, it is still
> possible for a separate read-only thread to see inconsistent data.
> This is a consequence of the Java Memory Model, which allows threads
> to cache data for performance reasons.
> In the absence of the correct synch., the values written in one thread
> may never be seen by another thread, or may be seen in a different
> order.

Right. You need to synchronize access (read and write) to the entire DOM to
have a correct program and think I've stressed that many times on this
list, though suspect John is just looking for any work around at this point
which provides relief for his application on the specific JVM / platform
he's using which may in practice update the data on each thread more
eagerly than required by the Java Memory Model and/or not reorder the
writes in such a way that the program breaks. You're skating on thin ice if
you're relying on this to work, but can understand folks trying it as a
last resort.

> Both the writer and reader threads need to synchronise on the *same*
> lock to ensure that the updated data is published correctly.
> [There are some other ways of doing this, e.g. volatile variables]
>
> This visibility issue is entirely separate from the issues that can be
> caused by failing to lock the whole transaction.
>
> Passing mutable data between threads needs to be handled very
> carefully to ensure the data is safely published.
>
> [A very good book on the subject is Java Concurrency in Practice by
> Goetz, Peierls, Bloch and others]
>
> ---------------------------------------------------------------------
> To unsubscribe, e-mail: j-users-unsubscr...@xerces.apache.org
> For additional commands, e-mail: j-users-h...@xerces.apache.org

Thanks.

Michael Glavassevich
XML Parser Development
IBM Toronto Lab
E-mail: mrgla...@ca.ibm.com
E-mail: mrgla...@apache.org

Reply via email to