class sun.rmi.transport.tcp.TCPTransport$AcceptLoop implements java.lang.Runnable
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.rmi.transport.tcp.TCPTransport$AcceptLoop
  super_class: java.lang.Object
{
  private final java.net.ServerSocket serverSocket;
    descriptor: Ljava/net/ServerSocket;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

  final sun.rmi.transport.tcp.TCPTransport this$0;
    descriptor: Lsun/rmi/transport/tcp/TCPTransport;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(sun.rmi.transport.tcp.TCPTransport, java.net.ServerSocket);
    descriptor: (Lsun/rmi/transport/tcp/TCPTransport;Ljava/net/ServerSocket;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
        start local 2 // java.net.ServerSocket serverSocket
         0: .line 360
            aload 0 /* this */
            aload 1
            putfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.this$0:Lsun/rmi/transport/tcp/TCPTransport;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 357
            aload 0 /* this */
            lconst_0
            putfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.lastExceptionTime:J
         2: .line 361
            aload 0 /* this */
            aload 2 /* serverSocket */
            putfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.serverSocket:Ljava/net/ServerSocket;
         3: .line 362
            return
        end local 2 // java.net.ServerSocket serverSocket
        end local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    4     0          this  Lsun/rmi/transport/tcp/TCPTransport$AcceptLoop;
            0    4     2  serverSocket  Ljava/net/ServerSocket;
    MethodParameters:
              Name  Flags
      this$0        final
      serverSocket  

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
         0: .line 366
            aload 0 /* this */
            invokevirtual sun.rmi.transport.tcp.TCPTransport$AcceptLoop.executeAcceptLoop:()V
         1: .line 367
            goto 7
      StackMap locals:
      StackMap stack: java.lang.Throwable
         2: astore 1
         3: .line 375
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.serverSocket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.close:()V
         4: .line 376
            goto 6
      StackMap locals: sun.rmi.transport.tcp.TCPTransport$AcceptLoop java.lang.Throwable
      StackMap stack: java.io.IOException
         5: pop
         6: .line 378
      StackMap locals:
      StackMap stack:
            aload 1
            athrow
         7: .line 375
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.serverSocket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.close:()V
         8: .line 376
            goto 10
      StackMap locals:
      StackMap stack: java.io.IOException
         9: pop
        10: .line 379
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lsun/rmi/transport/tcp/TCPTransport$AcceptLoop;
      Exception table:
        from    to  target  type
           0     2       2  any
           3     4       5  Class java.io.IOException
           7     8       9  Class java.io.IOException

  private void executeAcceptLoop();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=4, args_size=1
        start local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
         0: .line 386
            getstatic sun.rmi.transport.tcp.TCPTransport.tcpLog:Lsun/rmi/runtime/Log;
            getstatic sun.rmi.runtime.Log.BRIEF:Ljava/util/logging/Level;
            invokevirtual sun.rmi.runtime.Log.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 4
         1: .line 387
            getstatic sun.rmi.transport.tcp.TCPTransport.tcpLog:Lsun/rmi/runtime/Log;
            getstatic sun.rmi.runtime.Log.BRIEF:Ljava/util/logging/Level;
            new java.lang.StringBuilder
            dup
            ldc "listening on port "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 388
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.this$0:Lsun/rmi/transport/tcp/TCPTransport;
            invokevirtual sun.rmi.transport.tcp.TCPTransport.getEndpoint:()Lsun/rmi/transport/tcp/TCPEndpoint;
            invokevirtual sun.rmi.transport.tcp.TCPEndpoint.getPort:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 387
            invokevirtual sun.rmi.runtime.Log.log:(Ljava/util/logging/Level;Ljava/lang/String;)V
         4: .line 392
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 1 /* socket */
        start local 1 // java.net.Socket socket
         5: .line 394
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.serverSocket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.accept:()Ljava/net/Socket;
            astore 1 /* socket */
         6: .line 399
            aload 1 /* socket */
            invokevirtual java.net.Socket.getInetAddress:()Ljava/net/InetAddress;
            astore 2 /* clientAddr */
        start local 2 // java.net.InetAddress clientAddr
         7: .line 400
            aload 2 /* clientAddr */
            ifnull 9
         8: .line 401
            aload 2 /* clientAddr */
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            goto 10
         9: .line 402
      StackMap locals: java.net.Socket java.net.InetAddress
      StackMap stack:
            ldc "0.0.0.0"
        10: .line 400
      StackMap locals:
      StackMap stack: java.lang.String
            astore 3 /* clientHost */
        start local 3 // java.lang.String clientHost
        11: .line 409
            getstatic sun.rmi.transport.tcp.TCPTransport.connectionThreadPool:Ljava/util/concurrent/ExecutorService;
        12: .line 410
            new sun.rmi.transport.tcp.TCPTransport$ConnectionHandler
            dup
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.this$0:Lsun/rmi/transport/tcp/TCPTransport;
            aload 1 /* socket */
            aload 3 /* clientHost */
            invokespecial sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.<init>:(Lsun/rmi/transport/tcp/TCPTransport;Ljava/net/Socket;Ljava/lang/String;)V
        13: .line 409
            invokeinterface java.util.concurrent.ExecutorService.execute:(Ljava/lang/Runnable;)V
        14: .line 411
            goto 4
      StackMap locals: sun.rmi.transport.tcp.TCPTransport$AcceptLoop java.net.Socket java.net.InetAddress java.lang.String
      StackMap stack: java.util.concurrent.RejectedExecutionException
        15: pop
        16: .line 412
            aload 1 /* socket */
            invokestatic sun.rmi.transport.tcp.TCPTransport.closeSocket:(Ljava/net/Socket;)V
        17: .line 413
            getstatic sun.rmi.transport.tcp.TCPTransport.tcpLog:Lsun/rmi/runtime/Log;
            getstatic sun.rmi.runtime.Log.BRIEF:Ljava/util/logging/Level;
        18: .line 414
            new java.lang.StringBuilder
            dup
            ldc "rejected connection from "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* clientHost */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 413
            invokevirtual sun.rmi.runtime.Log.log:(Ljava/util/logging/Level;Ljava/lang/String;)V
        end local 3 // java.lang.String clientHost
        end local 2 // java.net.InetAddress clientAddr
        20: .line 417
            goto 4
      StackMap locals: sun.rmi.transport.tcp.TCPTransport$AcceptLoop java.net.Socket
      StackMap stack: java.lang.Throwable
        21: astore 2 /* t */
        start local 2 // java.lang.Throwable t
        22: .line 425
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.serverSocket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.isClosed:()Z
            ifeq 26
        23: .line 443
            aload 1 /* socket */
            ifnull 54
        24: .line 444
            aload 1 /* socket */
            invokestatic sun.rmi.transport.tcp.TCPTransport.closeSocket:(Ljava/net/Socket;)V
        25: .line 426
            goto 54
        26: .line 430
      StackMap locals: java.lang.Throwable
      StackMap stack:
            getstatic sun.rmi.transport.tcp.TCPTransport.tcpLog:Lsun/rmi/runtime/Log;
            getstatic java.util.logging.Level.WARNING:Ljava/util/logging/Level;
            invokevirtual sun.rmi.runtime.Log.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 40
        27: .line 431
            getstatic sun.rmi.transport.tcp.TCPTransport.tcpLog:Lsun/rmi/runtime/Log;
            getstatic java.util.logging.Level.WARNING:Ljava/util/logging/Level;
        28: .line 432
            new java.lang.StringBuilder
            dup
            ldc "accept loop for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.serverSocket:Ljava/net/ServerSocket;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        29: .line 433
            ldc " throws"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        30: .line 432
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        31: .line 433
            aload 2 /* t */
        32: .line 431
            invokevirtual sun.rmi.runtime.Log.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
        33: .line 435
            goto 40
      StackMap locals:
      StackMap stack: java.lang.Throwable
        34: pop
        35: .line 437
            goto 40
      StackMap locals:
      StackMap stack: java.lang.Throwable
        36: astore 3
        37: .line 443
            aload 1 /* socket */
            ifnull 39
        38: .line 444
            aload 1 /* socket */
            invokestatic sun.rmi.transport.tcp.TCPTransport.closeSocket:(Ljava/net/Socket;)V
        39: .line 446
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3
            athrow
        40: .line 443
      StackMap locals:
      StackMap stack:
            aload 1 /* socket */
            ifnull 42
        41: .line 444
            aload 1 /* socket */
            invokestatic sun.rmi.transport.tcp.TCPTransport.closeSocket:(Ljava/net/Socket;)V
        42: .line 452
      StackMap locals:
      StackMap stack:
            aload 2 /* t */
            instanceof java.lang.SecurityException
            ifne 46
        43: .line 454
            invokestatic sun.rmi.transport.tcp.TCPEndpoint.shedConnectionCaches:()V
        44: .line 455
            goto 46
      StackMap locals:
      StackMap stack: java.lang.Throwable
        45: pop
        46: .line 464
      StackMap locals:
      StackMap stack:
            aload 2 /* t */
            instanceof java.lang.Exception
            ifne 49
        47: .line 465
            aload 2 /* t */
            instanceof java.lang.OutOfMemoryError
            ifne 49
        48: .line 466
            aload 2 /* t */
            instanceof java.lang.NoClassDefFoundError
            ifeq 51
        49: .line 468
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* t */
            invokevirtual sun.rmi.transport.tcp.TCPTransport$AcceptLoop.continueAfterAcceptFailure:(Ljava/lang/Throwable;)Z
            ifne 4
        50: .line 469
            return
        51: .line 472
      StackMap locals:
      StackMap stack:
            aload 2 /* t */
            instanceof java.lang.Error
            ifeq 53
        52: .line 473
            aload 2 /* t */
            checkcast java.lang.Error
            athrow
        53: .line 475
      StackMap locals:
      StackMap stack:
            new java.lang.reflect.UndeclaredThrowableException
            dup
            aload 2 /* t */
            invokespecial java.lang.reflect.UndeclaredThrowableException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.lang.Throwable t
        end local 1 // java.net.Socket socket
        54: .line 479
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   55     0        this  Lsun/rmi/transport/tcp/TCPTransport$AcceptLoop;
            5   54     1      socket  Ljava/net/Socket;
            7   20     2  clientAddr  Ljava/net/InetAddress;
           11   20     3  clientHost  Ljava/lang/String;
           22   54     2           t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
          11    14      15  Class java.util.concurrent.RejectedExecutionException
           5    20      21  Class java.lang.Throwable
          26    33      34  Class java.lang.Throwable
          22    23      36  any
          26    36      36  any
          43    44      45  Class java.lang.Throwable

  private boolean continueAfterAcceptFailure(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
        start local 1 // java.lang.Throwable t
         0: .line 491
            invokestatic java.rmi.server.RMISocketFactory.getFailureHandler:()Ljava/rmi/server/RMIFailureHandler;
            astore 2 /* fh */
        start local 2 // java.rmi.server.RMIFailureHandler fh
         1: .line 492
            aload 2 /* fh */
            ifnull 5
         2: .line 493
            aload 2 /* fh */
            aload 1 /* t */
            instanceof java.lang.Exception
            ifeq 3
            aload 1 /* t */
            checkcast java.lang.Exception
            goto 4
         3: .line 494
      StackMap locals: sun.rmi.transport.tcp.TCPTransport$AcceptLoop java.lang.Throwable java.rmi.server.RMIFailureHandler
      StackMap stack: java.rmi.server.RMIFailureHandler
            new java.lang.reflect.InvocationTargetException
            dup
            aload 1 /* t */
            invokespecial java.lang.reflect.InvocationTargetException.<init>:(Ljava/lang/Throwable;)V
         4: .line 493
      StackMap locals: sun.rmi.transport.tcp.TCPTransport$AcceptLoop java.lang.Throwable java.rmi.server.RMIFailureHandler
      StackMap stack: java.rmi.server.RMIFailureHandler java.lang.Exception
            invokeinterface java.rmi.server.RMIFailureHandler.failure:(Ljava/lang/Exception;)Z
            ireturn
         5: .line 496
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.rmi.transport.tcp.TCPTransport$AcceptLoop.throttleLoopOnException:()V
         6: .line 497
            iconst_1
            ireturn
        end local 2 // java.rmi.server.RMIFailureHandler fh
        end local 1 // java.lang.Throwable t
        end local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/rmi/transport/tcp/TCPTransport$AcceptLoop;
            0    7     1     t  Ljava/lang/Throwable;
            1    7     2    fh  Ljava/rmi/server/RMIFailureHandler;
    MethodParameters:
      Name  Flags
      t     

  private void throttleLoopOnException();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
         0: .line 507
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 1 /* now */
        start local 1 // long now
         1: .line 508
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.lastExceptionTime:J
            lconst_0
            lcmp
            ifeq 2
            lload 1 /* now */
            aload 0 /* this */
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.lastExceptionTime:J
            lsub
            ldc 5000
            lcmp
            ifle 5
         2: .line 510
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            lload 1 /* now */
            putfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.lastExceptionTime:J
         3: .line 511
            aload 0 /* this */
            iconst_0
            putfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.recentExceptionCount:I
         4: .line 512
            goto 9
         5: .line 514
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.recentExceptionCount:I
            iconst_1
            iadd
            dup_x1
            putfield sun.rmi.transport.tcp.TCPTransport$AcceptLoop.recentExceptionCount:I
            bipush 10
            if_icmplt 9
         6: .line 516
            ldc 10000
            invokestatic java.lang.Thread.sleep:(J)V
         7: .line 517
            goto 9
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         8: pop
         9: .line 521
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long now
        end local 0 // sun.rmi.transport.tcp.TCPTransport$AcceptLoop this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lsun/rmi/transport/tcp/TCPTransport$AcceptLoop;
            1   10     1   now  J
      Exception table:
        from    to  target  type
           6     7       8  Class java.lang.InterruptedException
}
SourceFile: "TCPTransport.java"
NestHost: sun.rmi.transport.tcp.TCPTransport
InnerClasses:
  private AcceptLoop = sun.rmi.transport.tcp.TCPTransport$AcceptLoop of sun.rmi.transport.tcp.TCPTransport
  private ConnectionHandler = sun.rmi.transport.tcp.TCPTransport$ConnectionHandler of sun.rmi.transport.tcp.TCPTransport