public abstract class com.sun.jmx.remote.internal.ServerCommunicatorAdmin
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: com.sun.jmx.remote.internal.ServerCommunicatorAdmin
  super_class: java.lang.Object
{
  private long timestamp;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private final int[] lock;
    descriptor: [I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private int currentJobs;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private long timeout;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private boolean terminated;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private static final com.sun.jmx.remote.util.ClassLogger logger;
    descriptor: Lcom/sun/jmx/remote/util/ClassLogger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final com.sun.jmx.remote.util.ClassLogger timelogger;
    descriptor: Lcom/sun/jmx/remote/util/ClassLogger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 230
            new com.sun.jmx.remote.util.ClassLogger
            dup
            ldc "javax.management.remote.misc"
         1: .line 231
            ldc "ServerCommunicatorAdmin"
         2: .line 230
            invokespecial com.sun.jmx.remote.util.ClassLogger.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         3: .line 229
            putstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
         4: .line 233
            new com.sun.jmx.remote.util.ClassLogger
            dup
            ldc "javax.management.remote.timeout"
         5: .line 234
            ldc "ServerCommunicatorAdmin"
         6: .line 233
            invokespecial com.sun.jmx.remote.util.ClassLogger.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         7: .line 232
            putstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.timelogger:Lcom/sun/jmx/remote/util/ClassLogger;
         8: .line 234
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=5, args_size=2
        start local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
        start local 1 // long timeout
         0: .line 32
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 221
            aload 0 /* this */
            iconst_0
            newarray 10
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.lock:[I
         2: .line 222
            aload 0 /* this */
            iconst_0
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.currentJobs:I
         3: .line 227
            aload 0 /* this */
            iconst_0
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.terminated:Z
         4: .line 33
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            invokevirtual com.sun.jmx.remote.util.ClassLogger.traceOn:()Z
            ifeq 10
         5: .line 34
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            ldc "Constructor"
         6: .line 35
            new java.lang.StringBuilder
            dup
            ldc "Creates a new ServerCommunicatorAdmin object with the timeout "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         7: .line 36
            lload 1 /* timeout */
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
         8: .line 35
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 34
            invokevirtual com.sun.jmx.remote.util.ClassLogger.trace:(Ljava/lang/String;Ljava/lang/String;)V
        10: .line 39
      StackMap locals: com.sun.jmx.remote.internal.ServerCommunicatorAdmin long
      StackMap stack:
            aload 0 /* this */
            lload 1 /* timeout */
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.timeout:J
        11: .line 41
            aload 0 /* this */
            lconst_0
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.timestamp:J
        12: .line 42
            lload 1 /* timeout */
            ldc 9223372036854775807
            lcmp
            ifge 23
        13: .line 43
            new com.sun.jmx.remote.internal.ServerCommunicatorAdmin$Timeout
            dup
            aload 0 /* this */
            invokespecial com.sun.jmx.remote.internal.ServerCommunicatorAdmin$Timeout.<init>:(Lcom/sun/jmx/remote/internal/ServerCommunicatorAdmin;)V
            astore 3 /* timeoutTask */
        start local 3 // java.lang.Runnable timeoutTask
        14: .line 44
            new java.lang.Thread
            dup
            aconst_null
        15: .line 45
            aload 3 /* timeoutTask */
        16: .line 46
            ldc "JMX-Server-Admin-Timeout"
        17: .line 47
            lconst_0
        18: .line 48
            iconst_0
        19: .line 44
            invokespecial java.lang.Thread.<init>:(Ljava/lang/ThreadGroup;Ljava/lang/Runnable;Ljava/lang/String;JZ)V
            astore 4 /* t */
        start local 4 // java.lang.Thread t
        20: .line 49
            aload 4 /* t */
            new java.lang.StringBuilder
            dup
            ldc "JMX server connection timeout "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* t */
            invokevirtual java.lang.Thread.getId:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.Thread.setName:(Ljava/lang/String;)V
        21: .line 52
            aload 4 /* t */
            iconst_1
            invokevirtual java.lang.Thread.setDaemon:(Z)V
        22: .line 53
            aload 4 /* t */
            invokevirtual java.lang.Thread.start:()V
        end local 4 // java.lang.Thread t
        end local 3 // java.lang.Runnable timeoutTask
        23: .line 55
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long timeout
        end local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   24     0         this  Lcom/sun/jmx/remote/internal/ServerCommunicatorAdmin;
            0   24     1      timeout  J
           14   23     3  timeoutTask  Ljava/lang/Runnable;
           20   23     4            t  Ljava/lang/Thread;
    MethodParameters:
         Name  Flags
      timeout  

  public boolean reqIncoming();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
         0: .line 67
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            invokevirtual com.sun.jmx.remote.util.ClassLogger.traceOn:()Z
            ifeq 2
         1: .line 68
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            ldc "reqIncoming"
            ldc "Receive a new request."
            invokevirtual com.sun.jmx.remote.util.ClassLogger.trace:(Ljava/lang/String;Ljava/lang/String;)V
         2: .line 71
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.lock:[I
            dup
            astore 1
            monitorenter
         3: .line 72
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.terminated:Z
            ifeq 7
         4: .line 73
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            ldc "reqIncoming"
         5: .line 74
            ldc "The server has decided to close this client connection."
         6: .line 73
            invokevirtual com.sun.jmx.remote.util.ClassLogger.warning:(Ljava/lang/String;Ljava/lang/String;)V
         7: .line 77
      StackMap locals: int[]
      StackMap stack:
            aload 0 /* this */
            dup
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.currentJobs:I
            iconst_1
            iadd
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.currentJobs:I
         8: .line 79
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.terminated:Z
            aload 1
            monitorexit
         9: ireturn
        10: .line 71
      StackMap locals:
      StackMap stack: java.lang.Throwable
            aload 1
            monitorexit
        11: athrow
        end local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lcom/sun/jmx/remote/internal/ServerCommunicatorAdmin;
      Exception table:
        from    to  target  type
           3     9      10  any
          10    11      10  any

  public boolean rspOutgoing();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
         0: .line 90
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            invokevirtual com.sun.jmx.remote.util.ClassLogger.traceOn:()Z
            ifeq 2
         1: .line 91
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            ldc "reqIncoming"
            ldc "Finish a request."
            invokevirtual com.sun.jmx.remote.util.ClassLogger.trace:(Ljava/lang/String;Ljava/lang/String;)V
         2: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.lock:[I
            dup
            astore 1
            monitorenter
         3: .line 95
            aload 0 /* this */
            dup
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.currentJobs:I
            iconst_1
            isub
            dup_x1
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.currentJobs:I
            ifne 7
         4: .line 96
            aload 0 /* this */
            invokestatic java.lang.System.currentTimeMillis:()J
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.timestamp:J
         5: .line 97
            aload 0 /* this */
            ldc "Admin: Timestamp="
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.timestamp:J
            invokevirtual com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logtime:(Ljava/lang/String;J)V
         6: .line 99
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.lock:[I
            invokevirtual java.lang.Object.notify:()V
         7: .line 101
      StackMap locals: int[]
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.terminated:Z
            aload 1
            monitorexit
         8: ireturn
         9: .line 94
      StackMap locals:
      StackMap stack: java.lang.Throwable
            aload 1
            monitorexit
        10: athrow
        end local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lcom/sun/jmx/remote/internal/ServerCommunicatorAdmin;
      Exception table:
        from    to  target  type
           3     8       9  any
           9    10       9  any

  protected abstract void doStop();
    descriptor: ()V
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT

  public void terminate();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
         0: .line 115
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            invokevirtual com.sun.jmx.remote.util.ClassLogger.traceOn:()Z
            ifeq 4
         1: .line 116
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.logger:Lcom/sun/jmx/remote/util/ClassLogger;
            ldc "terminate"
         2: .line 117
            ldc "terminate the ServerCommunicatorAdmin object."
         3: .line 116
            invokevirtual com.sun.jmx.remote.util.ClassLogger.trace:(Ljava/lang/String;Ljava/lang/String;)V
         4: .line 120
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.lock:[I
            dup
            astore 1
            monitorenter
         5: .line 121
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.terminated:Z
            ifeq 8
         6: .line 122
            aload 1
            monitorexit
         7: return
         8: .line 125
      StackMap locals: int[]
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.terminated:Z
         9: .line 128
            aload 0 /* this */
            getfield com.sun.jmx.remote.internal.ServerCommunicatorAdmin.lock:[I
            invokevirtual java.lang.Object.notify:()V
        10: .line 120
            aload 1
            monitorexit
        11: goto 14
      StackMap locals:
      StackMap stack: java.lang.Throwable
        12: aload 1
            monitorexit
        13: athrow
        14: .line 130
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   15     0  this  Lcom/sun/jmx/remote/internal/ServerCommunicatorAdmin;
      Exception table:
        from    to  target  type
           5     7      12  any
           8    11      12  any
          12    13      12  any

  private void logtime(java.lang.String, long);
    descriptor: (Ljava/lang/String;J)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
        start local 1 // java.lang.String desc
        start local 2 // long time
         0: .line 213
            getstatic com.sun.jmx.remote.internal.ServerCommunicatorAdmin.timelogger:Lcom/sun/jmx/remote/util/ClassLogger;
            ldc "synchro"
            new java.lang.StringBuilder
            dup
            aload 1 /* desc */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            lload 2 /* time */
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual com.sun.jmx.remote.util.ClassLogger.trace:(Ljava/lang/String;Ljava/lang/String;)V
         1: .line 214
            return
        end local 2 // long time
        end local 1 // java.lang.String desc
        end local 0 // com.sun.jmx.remote.internal.ServerCommunicatorAdmin this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/sun/jmx/remote/internal/ServerCommunicatorAdmin;
            0    2     1  desc  Ljava/lang/String;
            0    2     2  time  J
    MethodParameters:
      Name  Flags
      desc  
      time  
}
SourceFile: "ServerCommunicatorAdmin.java"
NestMembers:
  com.sun.jmx.remote.internal.ServerCommunicatorAdmin$Timeout
InnerClasses:
  private Timeout = com.sun.jmx.remote.internal.ServerCommunicatorAdmin$Timeout of com.sun.jmx.remote.internal.ServerCommunicatorAdmin