[Python-ideas] Monitor implementation for the stdlib?

George Sakkis george.sakkis at gmail.com
Mon Oct 22 20:07:37 CEST 2007


On 10/22/07, Adam Olsen <rhamph at gmail.com> wrote:
> On 10/22/07, George Sakkis <george.sakkis at gmail.com> wrote:
> > On 10/22/07, Adam Olsen <rhamph at gmail.com> wrote:
> >
> > > A method is often *NOT* the
> > > correct granularity to achieve a thread-safe API!  Consider:
> > >
> > > l = ... some "thread-safe" list ...
> > > if l:
> > >     x = l.pop()
> > >
> > > There's two method calls, so you cannot guarantee the object hasn't
> > > changed between them.  I get the impression this is regarded as a
> > > major mistake in Java's extensive use of monitors - plastering locks
> > > everywhere just isn't good enough.
> >
> > My Java's kinda rusty but IIRC one can use synchronized blocks on an
> > object to achieve finer granularity.
>
> You need coarser granularity to achieve correctness in this case.

Well I was talking from the POV of the enclosing method, i.e. something like:

l = ... some "thread-safe" list ...
synchronized(I) {
    if l:
        x = l.pop()
}


George



More information about the Python-ideas mailing list