Lock in Java

We are already aware of basic concepts around thread synchronization and various mechanisms using synchronized keyword. A lock interface is a thread synchronization aid like synchronized block except lock can be used in a more sophisticated way than Java’s synchronized blocks.

A lock is a tool for controlling access to a shared resource by multiple threads. Commonly, a lock provides exclusive access to a shared resource: only one thread at a time can acquire the lock and all access to the shared resource requires that the lock be acquired first. Since java.util.concurrent.locks.Lock is an interface, you need to use one of its implementations to use a Lock in your applications. ReentrantLock is one such implementation of Lock interface.
However, some locks may allow concurrent access to a shared resource, such as the read lock of a ReadWriteLock.

Below code snippets show how to use Lock API

Lock l = ...;
try {
    // access the resource protected by this lock
} finally {

First a Lock is created. Then it’s lock() method is called. Now the Lock instance is locked. Any other thread calling lock() will be blocked until the thread that locked the lock calls unlock(). Finally unlock() is called, and the Lock is now unlocked so other threads can lock it. It is recommended to call the lock.unlock() from finally block so that lock is released appropriately when necessary.

Difference between Lock API and synchronized keyword

The main differences between a Lock and a synchronized block are:

1) Java Lock API provides more visibility and options for locking, unlike synchronized where a thread might end up waiting indefinitely for the lock, we can use tryLock(long timeout, TimeUnit timeUnit) to make sure thread waits for specific time only.
2) The synchronized block must be fully contained within a single method whereas we can acquire the lock in one method and release it in another method with Lock API.
3) Lock interface forces to have try-finally block to make sure Lock is released even if some exception is thrown between lock() and unlock() method calls whereas synchronized block does not have such try-finally block mandate.

Method summary of Lock interface

void lock() – acquires the lock.
void lockInterruptibly() – acquires the lock unless the current thread is interrupted.
Condition newCondition() – returns a new Condition instance that is bound to this Lock instance.
boolean tryLock() – acquires the lock only if it is free at the time of invocation.
boolean tryLock(long time, TimeUnit unit) – acquires the lock if it is free within the given waiting time and the current thread has not been interrupted.
void unlock() – releases the lock.

Please look at the implementation of Lock API ReentrantLock

You can also read ReadWriteLock

Thanks for reading.

Soumitra Roy Sarkar

I am a professional Web developer, Enterprise Application developer, Software Engineer and Blogger. Connect me on Roy Tutorials Twitter Facebook  Google Plus Linkedin

Leave a Reply

Your email address will not be published. Required fields are marked *