public class com.oracle.svm.hosted.DeadlockWatchdog implements java.io.Closeable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.oracle.svm.hosted.DeadlockWatchdog
  super_class: java.lang.Object
{
  private final int watchdogInterval;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean watchdogExitOnTimeout;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.Thread thread;
    descriptor: Ljava/lang/Thread;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile long nextDeadline;
    descriptor: J
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile boolean stopped;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
         0: .line 47
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 49
            aload 0 /* this */
            getstatic com.oracle.svm.core.SubstrateOptions.DeadlockWatchdogInterval:Lcom/oracle/svm/core/option/HostedOptionKey;
            invokevirtual com.oracle.svm.core.option.HostedOptionKey.getValue:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            putfield com.oracle.svm.hosted.DeadlockWatchdog.watchdogInterval:I
         2: .line 50
            aload 0 /* this */
            getstatic com.oracle.svm.core.SubstrateOptions.DeadlockWatchdogExitOnTimeout:Lcom/oracle/svm/core/option/HostedOptionKey;
            invokevirtual com.oracle.svm.core.option.HostedOptionKey.getValue:()Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            putfield com.oracle.svm.hosted.DeadlockWatchdog.watchdogExitOnTimeout:Z
         3: .line 52
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.watchdogInterval:I
            ifle 7
         4: .line 53
            aload 0 /* this */
            new java.lang.Thread
            dup
            aload 0 /* this */
            invokedynamic run(Lcom/oracle/svm/hosted/DeadlockWatchdog;)Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  com/oracle/svm/hosted/DeadlockWatchdog.watchdogThread()V (5)
                  ()V
            invokespecial java.lang.Thread.<init>:(Ljava/lang/Runnable;)V
            putfield com.oracle.svm.hosted.DeadlockWatchdog.thread:Ljava/lang/Thread;
         5: .line 54
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.thread:Ljava/lang/Thread;
            invokevirtual java.lang.Thread.start:()V
         6: .line 55
            goto 8
         7: .line 56
      StackMap locals: com.oracle.svm.hosted.DeadlockWatchdog
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield com.oracle.svm.hosted.DeadlockWatchdog.thread:Ljava/lang/Thread;
         8: .line 58
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lcom/oracle/svm/hosted/DeadlockWatchdog;

  public void recordActivity();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
         0: .line 61
            aload 0 /* this */
            invokestatic java.lang.System.currentTimeMillis:()J
            getstatic java.util.concurrent.TimeUnit.MINUTES:Ljava/util/concurrent/TimeUnit;
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.watchdogInterval:I
            i2l
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            ladd
            putfield com.oracle.svm.hosted.DeadlockWatchdog.nextDeadline:J
         1: .line 62
            return
        end local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/oracle/svm/hosted/DeadlockWatchdog;

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
         0: .line 66
            aload 0 /* this */
            iconst_1
            putfield com.oracle.svm.hosted.DeadlockWatchdog.stopped:Z
         1: .line 67
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.thread:Ljava/lang/Thread;
            ifnull 3
         2: .line 68
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.thread:Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
         3: .line 70
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/oracle/svm/hosted/DeadlockWatchdog;

  void watchdogThread();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=7, locals=10, args_size=1
        start local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
         0: .line 73
            aload 0 /* this */
            invokevirtual com.oracle.svm.hosted.DeadlockWatchdog.recordActivity:()V
         1: .line 75
            goto 24
         2: .line 76
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 1 /* now */
        start local 1 // long now
         3: .line 77
            lload 1 /* now */
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.nextDeadline:J
            lcmp
            iflt 21
         4: .line 78
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
         5: .line 79
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "=== Image generator watchdog detected no activity. This can be a sign of a deadlock during image building. Dumping all stack traces. Current time: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 80
            invokestatic com.oracle.svm.hosted.DeadlockWatchdog.threadDump:()V
         7: .line 81
            invokestatic java.lang.Runtime.getRuntime:()Ljava/lang/Runtime;
            astore 3 /* runtime */
        start local 3 // java.lang.Runtime runtime
         8: .line 83
            aload 3 /* runtime */
            invokevirtual java.lang.Runtime.totalMemory:()J
            ldc 1048576
            ldiv
            lstore 4 /* usedHeapSize */
        start local 4 // long usedHeapSize
         9: .line 84
            aload 3 /* runtime */
            invokevirtual java.lang.Runtime.freeMemory:()J
            ldc 1048576
            ldiv
            lstore 6 /* freeHeapSize */
        start local 6 // long freeHeapSize
        10: .line 85
            aload 3 /* runtime */
            invokevirtual java.lang.Runtime.maxMemory:()J
            ldc 1048576
            ldiv
            lstore 8 /* maximumHeapSize */
        start local 8 // long maximumHeapSize
        11: .line 86
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            ldc "=== Memory statistics (in MB):%n=== Used heap size: %d%n=== Free heap size: %d%n=== Maximum heap size: %d%n"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            lload 4 /* usedHeapSize */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_1
            lload 6 /* freeHeapSize */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_2
            lload 8 /* maximumHeapSize */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokevirtual java.io.PrintStream.printf:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;
            pop
        12: .line 87
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.flush:()V
        13: .line 89
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.watchdogExitOnTimeout:Z
            ifeq 20
        14: .line 90
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "=== Image generator watchdog is aborting image generation. To configure the watchdog, use the options "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        15: .line 91
            getstatic com.oracle.svm.core.SubstrateOptions.DeadlockWatchdogInterval:Lcom/oracle/svm/core/option/HostedOptionKey;
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.watchdogInterval:I
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            aconst_null
            invokestatic com.oracle.svm.core.option.SubstrateOptionsParser.commandArgument:(Lorg/graalvm/compiler/options/OptionKey;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " and "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        16: .line 92
            getstatic com.oracle.svm.core.SubstrateOptions.DeadlockWatchdogExitOnTimeout:Lcom/oracle/svm/core/option/HostedOptionKey;
            ldc "+"
            aconst_null
            invokestatic com.oracle.svm.core.option.SubstrateOptionsParser.commandArgument:(Lorg/graalvm/compiler/options/OptionKey;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 90
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        18: .line 97
            iconst_1
            invokestatic java.lang.System.exit:(I)V
        19: .line 99
            goto 21
        20: .line 100
      StackMap locals: com.oracle.svm.hosted.DeadlockWatchdog long java.lang.Runtime long long long
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.oracle.svm.hosted.DeadlockWatchdog.recordActivity:()V
        end local 8 // long maximumHeapSize
        end local 6 // long freeHeapSize
        end local 4 // long usedHeapSize
        end local 3 // java.lang.Runtime runtime
        21: .line 105
      StackMap locals: com.oracle.svm.hosted.DeadlockWatchdog long
      StackMap stack:
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.nextDeadline:J
            lload 1 /* now */
            lsub
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            lconst_1
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            invokestatic java.lang.Math.min:(JJ)J
            invokestatic java.lang.Thread.sleep:(J)V
        22: .line 106
            goto 24
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
        23: pop
        end local 1 // long now
        24: .line 75
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.oracle.svm.hosted.DeadlockWatchdog.stopped:Z
            ifeq 2
        25: .line 110
            return
        end local 0 // com.oracle.svm.hosted.DeadlockWatchdog this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   26     0             this  Lcom/oracle/svm/hosted/DeadlockWatchdog;
            3   24     1              now  J
            8   21     3          runtime  Ljava/lang/Runtime;
            9   21     4     usedHeapSize  J
           10   21     6     freeHeapSize  J
           11   21     8  maximumHeapSize  J
      Exception table:
        from    to  target  type
          21    22      23  Class java.lang.InterruptedException

  private static void threadDump();
    descriptor: ()V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=0
         0: .line 113
            invokestatic java.lang.management.ManagementFactory.getThreadMXBean:()Ljava/lang/management/ThreadMXBean;
            iconst_1
            iconst_1
            invokeinterface java.lang.management.ThreadMXBean.dumpAllThreads:(ZZ)[Ljava/lang/management/ThreadInfo;
            dup
            astore 3
            arraylength
            istore 2
            iconst_0
            istore 1
            goto 5
      StackMap locals: top int int java.lang.management.ThreadInfo[]
      StackMap stack:
         1: aload 3
            iload 1
            aaload
            astore 0 /* ti */
        start local 0 // java.lang.management.ThreadInfo ti
         2: .line 114
            aload 0 /* ti */
            invokestatic com.oracle.svm.hosted.DeadlockWatchdog.printThreadInfo:(Ljava/lang/management/ThreadInfo;)V
         3: .line 115
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getLockedSynchronizers:()[Ljava/lang/management/LockInfo;
            invokestatic com.oracle.svm.hosted.DeadlockWatchdog.printLockInfo:([Ljava/lang/management/LockInfo;)V
        end local 0 // java.lang.management.ThreadInfo ti
         4: .line 113
            iinc 1 1
      StackMap locals:
      StackMap stack:
         5: iload 1
            iload 2
            if_icmplt 1
         6: .line 117
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
         7: .line 118
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            2    4     0    ti  Ljava/lang/management/ThreadInfo;

  private static void printThreadInfo(java.lang.management.ThreadInfo);
    descriptor: (Ljava/lang/management/ThreadInfo;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=10, args_size=1
        start local 0 // java.lang.management.ThreadInfo ti
         0: .line 121
            new java.lang.StringBuilder
            dup
            new java.lang.StringBuilder
            dup
            ldc "\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getThreadName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getThreadId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc " in "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getThreadState:()Ljava/lang/Thread$State;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuilder sb
         1: .line 122
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getLockName:()Ljava/lang/String;
            ifnull 3
         2: .line 123
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            ldc " on lock="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getLockName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         3: .line 125
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.isSuspended:()Z
            ifeq 5
         4: .line 126
            aload 1 /* sb */
            ldc " (suspended)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         5: .line 128
      StackMap locals:
      StackMap stack:
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.isInNative:()Z
            ifeq 7
         6: .line 129
            aload 1 /* sb */
            ldc " (running in native)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 131
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            aload 1 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 133
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            ifnull 10
         9: .line 134
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "      owned by "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " Id="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getLockOwnerId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        10: .line 137
      StackMap locals:
      StackMap stack:
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getStackTrace:()[Ljava/lang/StackTraceElement;
            astore 2 /* stacktrace */
        start local 2 // java.lang.StackTraceElement[] stacktrace
        11: .line 138
            aload 0 /* ti */
            invokevirtual java.lang.management.ThreadInfo.getLockedMonitors:()[Ljava/lang/management/MonitorInfo;
            astore 3 /* monitors */
        start local 3 // java.lang.management.MonitorInfo[] monitors
        12: .line 139
            iconst_0
            istore 4 /* i */
        start local 4 // int i
        13: goto 23
        14: .line 140
      StackMap locals: java.lang.StackTraceElement[] java.lang.management.MonitorInfo[] int
      StackMap stack:
            aload 2 /* stacktrace */
            iload 4 /* i */
            aaload
            astore 5 /* ste */
        start local 5 // java.lang.StackTraceElement ste
        15: .line 141
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "    at "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* ste */
            invokevirtual java.lang.StackTraceElement.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        16: .line 142
            aload 3 /* monitors */
            dup
            astore 9
            arraylength
            istore 8
            iconst_0
            istore 7
            goto 21
      StackMap locals: java.lang.management.ThreadInfo java.lang.StringBuilder java.lang.StackTraceElement[] java.lang.management.MonitorInfo[] int java.lang.StackTraceElement top int int java.lang.management.MonitorInfo[]
      StackMap stack:
        17: aload 9
            iload 7
            aaload
            astore 6 /* mi */
        start local 6 // java.lang.management.MonitorInfo mi
        18: .line 143
            aload 6 /* mi */
            invokevirtual java.lang.management.MonitorInfo.getLockedStackDepth:()I
            iload 4 /* i */
            if_icmpne 20
        19: .line 144
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "      - locked "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* mi */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 6 // java.lang.management.MonitorInfo mi
        20: .line 142
      StackMap locals:
      StackMap stack:
            iinc 7 1
      StackMap locals:
      StackMap stack:
        21: iload 7
            iload 8
            if_icmplt 17
        end local 5 // java.lang.StackTraceElement ste
        22: .line 139
            iinc 4 /* i */ 1
      StackMap locals: java.lang.management.ThreadInfo java.lang.StringBuilder java.lang.StackTraceElement[] java.lang.management.MonitorInfo[] int
      StackMap stack:
        23: iload 4 /* i */
            aload 2 /* stacktrace */
            arraylength
            if_icmplt 14
        end local 4 // int i
        24: .line 148
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
        25: .line 149
            return
        end local 3 // java.lang.management.MonitorInfo[] monitors
        end local 2 // java.lang.StackTraceElement[] stacktrace
        end local 1 // java.lang.StringBuilder sb
        end local 0 // java.lang.management.ThreadInfo ti
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   26     0          ti  Ljava/lang/management/ThreadInfo;
            1   26     1          sb  Ljava/lang/StringBuilder;
           11   26     2  stacktrace  [Ljava/lang/StackTraceElement;
           12   26     3    monitors  [Ljava/lang/management/MonitorInfo;
           13   24     4           i  I
           15   22     5         ste  Ljava/lang/StackTraceElement;
           18   20     6          mi  Ljava/lang/management/MonitorInfo;
    MethodParameters:
      Name  Flags
      ti    

  private static void printLockInfo(java.lang.management.LockInfo[]);
    descriptor: ([Ljava/lang/management/LockInfo;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // java.lang.management.LockInfo[] locks
         0: .line 152
            aload 0 /* locks */
            arraylength
            ifle 8
         1: .line 153
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "    Locked synchronizers: count = "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* locks */
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 154
            aload 0 /* locks */
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 6
      StackMap locals: java.lang.management.LockInfo[] top int int java.lang.management.LockInfo[]
      StackMap stack:
         3: aload 4
            iload 2
            aaload
            astore 1 /* li */
        start local 1 // java.lang.management.LockInfo li
         4: .line 155
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "      - "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* li */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 1 // java.lang.management.LockInfo li
         5: .line 154
            iinc 2 1
      StackMap locals:
      StackMap stack:
         6: iload 2
            iload 3
            if_icmplt 3
         7: .line 157
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
         8: .line 159
      StackMap locals: java.lang.management.LockInfo[]
      StackMap stack:
            return
        end local 0 // java.lang.management.LockInfo[] locks
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    9     0  locks  [Ljava/lang/management/LockInfo;
            4    5     1     li  Ljava/lang/management/LockInfo;
    MethodParameters:
       Name  Flags
      locks  
}
SourceFile: "DeadlockWatchdog.java"
InnerClasses:
  public final State = java.lang.Thread$State of java.lang.Thread
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles