Easy learning with example program codes

reentrantlock in java

The ReentrantLock class implements the Lock interface. It is the most widely used implementation class of Lock interface. It works in same way as synchronized keyword with extended capabilities.

As the name suggest, it allows threads to re-enter into lock on a resource more than once. When the thread first enters into lock, a hold count is set to one. Before unlocking the thread can re-enter into lock again and every time hold count is incremented by one. For every unlock request, hold count is decremented by one and when hold count is 0, the resource is unlocked.


import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.locks.ReentrantLock;
public class LockTest {
  public static void main(String[] args) {
	ExecutorService executorService = Executors.newFixedThreadPool(2);
        ReentrantLockMethodsCounter lockMethodsCounter = new ReentrantLockMethodsCounter();
        executorService.submit(() -> {
           System.out.println("IncrementCount (First Thread) : " +
        executorService.submit(() -> {
            System.out.println("IncrementCount (Second Thread) : " +
class ReentrantLockMethodsCounter {
    private final ReentrantLock lock = new ReentrantLock();
    private int count = 0;
    public int incrementAndGetCounter() {
        boolean isAcquired = lock.tryLock();
        System.out.println("Lock Acquired : " + isAcquired);
        if(isAcquired) {
            try {
                count = count + 1;
            } catch (InterruptedException e) {
                throw new IllegalStateException(e);
            } finally {
        return count;
class ReentrantLockCounter {
    private final ReentrantLock lock = new ReentrantLock();
    private int count = 0;
    //Use Lock For Thread Safe Increment
    public void increment() {
        try {
            count = count + 1;
        } finally {


Lock Acquired : true
Lock Acquired : false
IncrementCount (Second Thread) : 0
IncrementCount (First Thread) : 1

The basic idea behind locking is to acquire the lock when any thread calls increment method. Thread will release the lock after incrementing the variable so that other waiting threads can acquires the lock.

We have used try-catch block to ensure that the lock is released if any exception occurs.

Related topics

Posted in Java   

Core Java Tutorial

Programming language overview.
Overview of Java.
Java features
JVM architecture details.
Java Coding Guidelines.
Some important definitions.
Variable and data types.
Hello world java program.
Core java examples programs.
Important Java Programs.
How to set permanent path in java?
OOPs Basics.
Object and Class in Java.
OOPs Principles/Concepts.
Abstraction in java.
Encapsulation in java.
Polymorphism in java.
Method overloading in java.
Method overriding in java.
Dynamic method dispatch.
Runtime polymorphism.
Association in java.
Inheritance in java.
Aggregation in java.
Command line arguments in java.
Command line argument program in eclipse.
Read input from command line using Scanner.
Java array programs
Java star pattern programs
Java number pattern programs
final in java.
Abstract class in java.
Interface in java.
Custom marker Interface in java.
Constructor in java.
Package in java.
Access modifier in java.
Static import in java.
Package class in java.
this in java.
Instance initialize block.
Anonymous block.
super in java.
Static in java.
final in java.
Java cloning deep and shallow
Shallow vs Clone copy
String handling in java.
String handling programs.
StringBuffer in java.
StringBuilder in java.
Exception Handling Tutorial.
Multithreading Tutoial.
Java input output stream tutorial.
Collections framework in java tutorial.
Collections framework programs.
Java Random class
Java annotations.
Java design principles.
Java 7 features
Java 8 features
Java networking tutorial
Java Reflection tutorial

Copyright © 2019 CodesJava Protection Status SiteMap Reference: Java Wiki