Package org.apache.hadoop.hbase.util
Class IdLock
java.lang.Object
org.apache.hadoop.hbase.util.IdLock
Allows multiple concurrent clients to lock on a numeric id with a minimal memory overhead. The
 intended usage is as follows:
 
 IdLock.Entry lockEntry = idLock.getLockEntry(id);
 try {
   // User code.
 } finally {
   idLock.releaseLockEntry(lockEntry);
 }
 - 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic final classAn entry returned to the client as a lock object
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate static final org.slf4j.Loggerprivate ConcurrentMap<Long,IdLock.Entry> 
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescription(package private) voidgetLockEntry(long id) Blocks until the lock corresponding to the given id is acquired.booleanisHeldByCurrentThread(long id) Test whether the given id is already locked by the current thread.voidreleaseLockEntry(IdLock.Entry entry) Must be called in a finally block to decrease the internal counter and remove the monitor object for the given id if the caller is the last client.tryLockEntry(long id, long time) Blocks until the lock corresponding to the given id is acquired.voidwaitForWaiters(long id, int numWaiters) 
- 
Field Details- 
LOG
- 
map
 
- 
- 
Constructor Details- 
IdLockpublic IdLock()
 
- 
- 
Method Details- 
getLockEntryBlocks until the lock corresponding to the given id is acquired.- Parameters:
- id- an arbitrary number to lock on
- Returns:
- an "entry" to pass to releaseLockEntry(Entry)to release the lock
- Throws:
- IOException- if interrupted
 
- 
tryLockEntryBlocks until the lock corresponding to the given id is acquired.- Parameters:
- id- an arbitrary number to lock on
- time- time to wait in ms
- Returns:
- an "entry" to pass to releaseLockEntry(Entry)to release the lock
- Throws:
- IOException- if interrupted
 
- 
releaseLockEntryMust be called in a finally block to decrease the internal counter and remove the monitor object for the given id if the caller is the last client.- Parameters:
- entry- the return value of- getLockEntry(long)
 
- 
isHeldByCurrentThreadTest whether the given id is already locked by the current thread.
- 
assertMapEmptyvoid assertMapEmpty()
- 
waitForWaiters- Throws:
- InterruptedException
 
 
-