org.jboss.cache.lock
Class LockStrategySerializable

java.lang.Object
  extended byorg.jboss.cache.lock.LockStrategySerializable
All Implemented Interfaces:
LockStrategy (src)

public class LockStrategySerializable
extends java.lang.Object
implements LockStrategy (src)

Lock strategy of Serializable that prevents dirty read, non-repeatable read, and phantom read.

Dirty read allows (t1) write and then (t2) read within two separate threads, all without transaction commit.

Non-repeatable read allows (t1) read, (t2) write, and then (t1) read, all without transaction commit.

Phantom read allows (t1) read n rows, (t2) insert k rows, and (t1) read n+k rows.


Constructor Summary
LockStrategySerializable()
           
 
Method Summary
 Sync readLock()
          Return a read lock object.
 Sync upgradeLockAttempt(long msecs)
          Attempt to upgrade the current read lock to write lock with msecs timeout.
 Sync writeLock()
          Return a write lock object.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

LockStrategySerializable

public LockStrategySerializable()
Method Detail

readLock

public Sync readLock()
Description copied from interface: LockStrategy (src)
Return a read lock object.

Specified by:
readLock in interface LockStrategy (src)
Returns:
Sync (@see EDU.oswego.cs.dl.util.concurrent.Sync)
See Also:
LockStrategy.readLock()

upgradeLockAttempt

public Sync upgradeLockAttempt(long msecs)
                        throws UpgradeException (src) 
Description copied from interface: LockStrategy (src)
Attempt to upgrade the current read lock to write lock with msecs timeout.

Specified by:
upgradeLockAttempt in interface LockStrategy (src)
Parameters:
msecs - Timeout in milliseconds.
Returns:
Sync object. Will return null if timeout or failed.
Throws:
UpgradeException (src)
See Also:
LockStrategy.upgradeLockAttempt(long)

writeLock

public Sync writeLock()
Description copied from interface: LockStrategy (src)
Return a write lock object.

Specified by:
writeLock in interface LockStrategy (src)
Returns:
Sync (@see EDU.oswego.cs.dl.util.concurrent.Sync)
See Also:
LockStrategy.writeLock()