Teachnique
      CourseRoadmaps
      Login

      OverviewHistoryFeaturesJava 8 - New Featuresvs C++Virtual Machine(JVM)JDK vs JRE vs JVMHello World ProgramEnvironment SetupBasic SyntaxVariable TypesData TypesType CastingUnicode SystemBasic OperatorsCommentsStreamsNew Date-Time API

      Loop ControlDecision Makingif-else Statementswitch statementfor loopfor each Loopwhile Loopdo...while Loopbreak Statementcontinue Statement

      OOPs (Object-Oriented Programming) ConceptsObject and ClassesClass AttributesClass MethodsMethodsVariable ScopesConstructorsAccess ModifiersInheritanceAggregationPolymorphismOverridingMethod OverloadingDynamic BindingStatic BindingInstance Initializer BlockAbstractionEncapsulationInterfacesPackagesInner classesStatic ClassesAnonymous ClassesSingleton ClassWrapper ClassesEnum Class

      Number ClassBoolean classCharacter ClassArraysMath Class

      File ClassCreating FilesWrite To FilesReading FileDelete FilesDirectory OperationsFiles and I/O

      ExceptionsTry Catch BlockTry with ResourcesMultiple Catch BlocksNested Try BlockFinally BlockThrows and Throw | Throw an ExceptionException PropagationBuilt-in ExceptionsCustom Exception

      MultithreadingThread Life CycleCreating a ThreadStarting a ThreadJoining ThreadsNaming a Thread with ExamplesScheduling Threads with ExamplesThread PoolsMain ThreadThread PriorityDaemon ThreadThreadGroup ClassJVM Shutdown Hook

      Thread SynchronizationBlock SynchronizationStatic SynchronizationInter Thread CommunicationThread DeadlockInterrupting ThreadThread ControlReentrant Monitor

      NetworkingSocket ProgrammingURL ProcessingURL ClassURLConnection ClassHttpURLConnection ClassSocket Class with ExamplesGenerics

      Collections FrameworkCollection Interface

      List InterfaceArrayList Class

      Queue InterfaceArrayDeque Class

      Map InterfaceSortedMap Interface

      Set InterfaceSortedSet Interface

      Data Structures Enumeration Interface BitSet Class

      How to Use Iterator?How to Use Comparator?How to Use Comparable?

      RecursionRegular ExpressionsSerializationString ClassJava Arrays - Class

      Feedback

      Submit request if you have any questions.

      Course
      Thread Deadlock

      Java Tutorial

      This Java tutorial is tailored for newcomers, offering a journey from basic principles to complex Java programming techniques. Completing this tutorial equips you with a solid understanding of Java, preparing you for advanced learning. You'll emerge ready to tackle the challenges of becoming a top-tier software engineer, with the skills to innovate and excel in the vast world of software development.

      Thread Deadlock

      Deadlock describes a situation where two or more threads are blocked forever, waiting for each other. Deadlock occurs when multiple threads need the same locks but obtain them in different order. A Java multithreaded program may suffer from the deadlock condition because the synchronized keyword causes the executing thread to block while waiting for the lock, or monitor, associated with the specified object. Here is an example.

      Example: Demonstrating Deadlock Situation

      public class TestThread {
      public static Object Lock1 = new Object();
      public static Object Lock2 = new Object();
      public static void main(String args[]) {
      ThreadDemo1 T1 = new ThreadDemo1();
      ThreadDemo2 T2 = new ThreadDemo2();
      T1.start();
      T2.start();
      }
      private static class ThreadDemo1 extends Thread {
      public void run() {
      synchronized (Lock1) {
      System.out.println("Thread 1: Holding lock 1...");
      try { Thread.sleep(10); }
      catch (InterruptedException e) {}
      System.out.println("Thread 1: Waiting for lock 2...");
      synchronized (Lock2) {
      System.out.println("Thread 1: Holding lock 1 & 2...");
      }
      }
      }
      }
      private static class ThreadDemo2 extends Thread {
      public void run() {
      synchronized (Lock2) {
      System.out.println("Thread 2: Holding lock 2...");
      try { Thread.sleep(10); }
      catch (InterruptedException e) {}
      System.out.println("Thread 2: Waiting for lock 1...");
      synchronized (Lock1) {
      System.out.println("Thread 2: Holding lock 1 & 2...");
      }
      }
      }
      }
      }
      When you compile and execute the above program, you find a deadlock situation and following is the output produced by the program

      Output

      Thread 1: Holding lock 1...
      Thread 2: Holding lock 2...
      Thread 1: Waiting for lock 2...
      Thread 2: Waiting for lock 1...
      The above program will hang forever because neither of the threads in position to proceed and waiting for each other to release the lock, so you can come out of the program by pressing CTRL+C.

      Deadlock Solution Example

      Let's change the order of the lock and run of the same program to see if both the threads still wait for each other

      Example

      public class TestThread {
      public static Object Lock1 = new Object();
      public static Object Lock2 = new Object();
      public static void main(String args[]) {
      ThreadDemo1 T1 = new ThreadDemo1();
      ThreadDemo2 T2 = new ThreadDemo2();
      T1.start();
      T2.start();
      }
      private static class ThreadDemo1 extends Thread {
      public void run() {
      synchronized (Lock1) {
      System.out.println("Thread 1: Holding lock 1...");
      try {
      Thread.sleep(10);
      } catch (InterruptedException e) {}
      System.out.println("Thread 1: Waiting for lock 2...");
      synchronized (Lock2) {
      System.out.println("Thread 1: Holding lock 1 & 2...");
      }
      }
      }
      }
      private static class ThreadDemo2 extends Thread {
      public void run() {
      synchronized (Lock1) {
      System.out.println("Thread 2: Holding lock 1...");
      try {
      Thread.sleep(10);
      } catch (InterruptedException e) {}
      System.out.println("Thread 2: Waiting for lock 2...");
      synchronized (Lock2) {
      System.out.println("Thread 2: Holding lock 1 & 2...");
      }
      }
      }
      }
      }
      So just changing the order of the locks prevent the program in going into a deadlock situation and completes with the following result

      Output

      Thread 1: Holding lock 1...
      Thread 1: Waiting for lock 2...
      Thread 1: Holding lock 1 & 2...
      Thread 2: Holding lock 1...
      Thread 2: Waiting for lock 2...
      Thread 2: Holding lock 1 & 2...
      The above example is to just make the concept clear, however, it is a complex concept and you should deep dive into it before you develop your applications to deal with deadlock situations.
      Print Page