final class org.xnio.nio.NioXnioWorker extends org.xnio.XnioWorker
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: org.xnio.nio.NioXnioWorker
  super_class: org.xnio.XnioWorker
{
  private static final int CLOSE_REQ;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -2147483648

  private static final int CLOSE_COMP;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1073741824

  private final long workerStackSize;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile int state;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private final org.xnio.nio.WorkerThread[] workerThreads;
    descriptor: [Lorg/xnio/nio/WorkerThread;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.xnio.nio.WorkerThread acceptThread;
    descriptor: Lorg/xnio/nio/WorkerThread;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.xnio.nio.NioXnioWorker$NioWorkerMetrics metrics;
    descriptor: Lorg/xnio/nio/NioXnioWorker$NioWorkerMetrics;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile java.lang.Thread shutdownWaiter;
    descriptor: Ljava/lang/Thread;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<org.xnio.nio.NioXnioWorker, java.lang.Thread> shutdownWaiterUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lorg/xnio/nio/NioXnioWorker;Ljava/lang/Thread;>;

  private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<org.xnio.nio.NioXnioWorker> stateUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lorg/xnio/nio/NioXnioWorker;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 78
            ldc Lorg/xnio/nio/NioXnioWorker;
            ldc Ljava/lang/Thread;
            ldc "shutdownWaiter"
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            putstatic org.xnio.nio.NioXnioWorker.shutdownWaiterUpdater:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         1: .line 80
            ldc Lorg/xnio/nio/NioXnioWorker;
            ldc "state"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            putstatic org.xnio.nio.NioXnioWorker.stateUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(org.xnio.XnioWorker$Builder);
    descriptor: (Lorg/xnio/XnioWorker$Builder;)V
    flags: (0x0000) 
    Code:
      stack=10, locals=17, args_size=2
        start local 0 // org.xnio.nio.NioXnioWorker this
        start local 1 // org.xnio.XnioWorker$Builder builder
         0: .line 84
            aload 0 /* this */
            aload 1 /* builder */
            invokespecial org.xnio.XnioWorker.<init>:(Lorg/xnio/XnioWorker$Builder;)V
         1: .line 69
            aload 0 /* this */
            iconst_1
            putfield org.xnio.nio.NioXnioWorker.state:I
         2: .line 85
            aload 1 /* builder */
            invokevirtual org.xnio.XnioWorker$Builder.getXnio:()Lorg/xnio/Xnio;
            checkcast org.xnio.nio.NioXnio
            astore 2 /* xnio */
        start local 2 // org.xnio.nio.NioXnio xnio
         3: .line 86
            aload 1 /* builder */
            invokevirtual org.xnio.XnioWorker$Builder.getWorkerIoThreads:()I
            istore 3 /* threadCount */
        start local 3 // int threadCount
         4: .line 87
            aload 0 /* this */
            aload 1 /* builder */
            invokevirtual org.xnio.XnioWorker$Builder.getWorkerStackSize:()J
            putfield org.xnio.nio.NioXnioWorker.workerStackSize:J
         5: .line 88
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.getName:()Ljava/lang/String;
            astore 4 /* workerName */
        start local 4 // java.lang.String workerName
         6: .line 90
            iload 3 /* threadCount */
            anewarray org.xnio.nio.WorkerThread
            astore 5 /* workerThreads */
        start local 5 // org.xnio.nio.WorkerThread[] workerThreads
         7: .line 91
            aload 1 /* builder */
            invokevirtual org.xnio.XnioWorker$Builder.getThreadGroup:()Ljava/lang/ThreadGroup;
            astore 6 /* threadGroup */
        start local 6 // java.lang.ThreadGroup threadGroup
         8: .line 92
            aload 1 /* builder */
            invokevirtual org.xnio.XnioWorker$Builder.isDaemon:()Z
            istore 7 /* markWorkerThreadAsDaemon */
        start local 7 // boolean markWorkerThreadAsDaemon
         9: .line 93
            iconst_0
            istore 8 /* ok */
        start local 8 // boolean ok
        10: .line 95
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        11: goto 21
        12: .line 98
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int int
      StackMap stack:
            aload 2 /* xnio */
            getfield org.xnio.nio.NioXnio.mainSelectorCreator:Lorg/xnio/nio/NioXnio$SelectorCreator;
            invokeinterface org.xnio.nio.NioXnio$SelectorCreator.open:()Ljava/nio/channels/Selector;
            astore 10 /* threadSelector */
        start local 10 // java.nio.channels.Selector threadSelector
        13: .line 99
            goto 16
        end local 10 // java.nio.channels.Selector threadSelector
      StackMap locals:
      StackMap stack: java.io.IOException
        14: astore 11 /* e */
        start local 11 // java.io.IOException e
        15: .line 100
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            aload 11 /* e */
            invokeinterface org.xnio.nio.Log.unexpectedSelectorOpenProblem:(Ljava/lang/Throwable;)Ljava/lang/IllegalStateException;
            athrow
        end local 11 // java.io.IOException e
        start local 10 // java.nio.channels.Selector threadSelector
        16: .line 102
      StackMap locals: java.nio.channels.Selector
      StackMap stack:
            new org.xnio.nio.WorkerThread
            dup
            aload 0 /* this */
            aload 10 /* threadSelector */
            ldc "%s I/O-%d"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 4 /* workerName */
            aastore
            dup
            iconst_1
            iload 9 /* i */
            iconst_1
            iadd
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            aload 6 /* threadGroup */
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerStackSize:J
            iload 9 /* i */
            invokespecial org.xnio.nio.WorkerThread.<init>:(Lorg/xnio/nio/NioXnioWorker;Ljava/nio/channels/Selector;Ljava/lang/String;Ljava/lang/ThreadGroup;JI)V
            astore 11 /* workerThread */
        start local 11 // org.xnio.nio.WorkerThread workerThread
        17: .line 104
            iload 7 /* markWorkerThreadAsDaemon */
            ifeq 19
        18: .line 105
            aload 11 /* workerThread */
            iconst_1
            invokevirtual org.xnio.nio.WorkerThread.setDaemon:(Z)V
        19: .line 107
      StackMap locals: org.xnio.nio.WorkerThread
      StackMap stack:
            aload 5 /* workerThreads */
            iload 9 /* i */
            aload 11 /* workerThread */
            aastore
        end local 11 // org.xnio.nio.WorkerThread workerThread
        end local 10 // java.nio.channels.Selector threadSelector
        20: .line 95
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        21: iload 9 /* i */
            iload 3 /* threadCount */
            if_icmplt 12
        end local 9 // int i
        22: .line 111
            aload 2 /* xnio */
            getfield org.xnio.nio.NioXnio.mainSelectorCreator:Lorg/xnio/nio/NioXnio$SelectorCreator;
            invokeinterface org.xnio.nio.NioXnio$SelectorCreator.open:()Ljava/nio/channels/Selector;
            astore 9 /* threadSelector */
        start local 9 // java.nio.channels.Selector threadSelector
        23: .line 112
            goto 26
        end local 9 // java.nio.channels.Selector threadSelector
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int
      StackMap stack: java.io.IOException
        24: astore 10 /* e */
        start local 10 // java.io.IOException e
        25: .line 113
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            aload 10 /* e */
            invokeinterface org.xnio.nio.Log.unexpectedSelectorOpenProblem:(Ljava/lang/Throwable;)Ljava/lang/IllegalStateException;
            athrow
        end local 10 // java.io.IOException e
        start local 9 // java.nio.channels.Selector threadSelector
        26: .line 115
      StackMap locals: java.nio.channels.Selector
      StackMap stack:
            aload 0 /* this */
            new org.xnio.nio.WorkerThread
            dup
            aload 0 /* this */
            aload 9 /* threadSelector */
            ldc "%s Accept"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 4 /* workerName */
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            aload 6 /* threadGroup */
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerStackSize:J
            iload 3 /* threadCount */
            invokespecial org.xnio.nio.WorkerThread.<init>:(Lorg/xnio/nio/NioXnioWorker;Ljava/nio/channels/Selector;Ljava/lang/String;Ljava/lang/ThreadGroup;JI)V
            putfield org.xnio.nio.NioXnioWorker.acceptThread:Lorg/xnio/nio/WorkerThread;
        27: .line 116
            iload 7 /* markWorkerThreadAsDaemon */
            ifeq 29
        28: .line 117
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.acceptThread:Lorg/xnio/nio/WorkerThread;
            iconst_1
            invokevirtual org.xnio.nio.WorkerThread.setDaemon:(Z)V
        29: .line 119
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 8 /* ok */
        end local 9 // java.nio.channels.Selector threadSelector
        30: .line 120
            goto 39
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int
      StackMap stack: java.lang.Throwable
        31: astore 12
        32: .line 121
            iload 8 /* ok */
            ifne 38
        33: .line 122
            aload 5 /* workerThreads */
            dup
            astore 16
            arraylength
            istore 15
            iconst_0
            istore 14
            goto 37
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int top top top java.lang.Throwable top int int org.xnio.nio.WorkerThread[]
      StackMap stack:
        34: aload 16
            iload 14
            aaload
            astore 13 /* worker */
        start local 13 // org.xnio.nio.WorkerThread worker
        35: .line 123
            aload 13 /* worker */
            ifnull 36
            aload 13 /* worker */
            invokevirtual org.xnio.nio.WorkerThread.getSelector:()Ljava/nio/channels/Selector;
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/nio/channels/Selector;)V
        end local 13 // org.xnio.nio.WorkerThread worker
        36: .line 122
      StackMap locals:
      StackMap stack:
            iinc 14 1
      StackMap locals:
      StackMap stack:
        37: iload 14
            iload 15
            if_icmplt 34
        38: .line 126
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int top top top java.lang.Throwable
      StackMap stack:
            aload 12
            athrow
        39: .line 121
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int
      StackMap stack:
            iload 8 /* ok */
            ifne 45
        40: .line 122
            aload 5 /* workerThreads */
            dup
            astore 16
            arraylength
            istore 15
            iconst_0
            istore 14
            goto 44
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int top top top top top int int org.xnio.nio.WorkerThread[]
      StackMap stack:
        41: aload 16
            iload 14
            aaload
            astore 13 /* worker */
        start local 13 // org.xnio.nio.WorkerThread worker
        42: .line 123
            aload 13 /* worker */
            ifnull 43
            aload 13 /* worker */
            invokevirtual org.xnio.nio.WorkerThread.getSelector:()Ljava/nio/channels/Selector;
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/nio/channels/Selector;)V
        end local 13 // org.xnio.nio.WorkerThread worker
        43: .line 122
      StackMap locals:
      StackMap stack:
            iinc 14 1
      StackMap locals:
      StackMap stack:
        44: iload 14
            iload 15
            if_icmplt 41
        45: .line 127
      StackMap locals: org.xnio.nio.NioXnioWorker org.xnio.XnioWorker$Builder org.xnio.nio.NioXnio int java.lang.String org.xnio.nio.WorkerThread[] java.lang.ThreadGroup int int
      StackMap stack:
            aload 0 /* this */
            aload 5 /* workerThreads */
            putfield org.xnio.nio.NioXnioWorker.workerThreads:[Lorg/xnio/nio/WorkerThread;
        46: .line 128
            aload 0 /* this */
            new org.xnio.nio.NioXnioWorker$NioWorkerMetrics
            dup
            aload 0 /* this */
            aload 4 /* workerName */
            invokespecial org.xnio.nio.NioXnioWorker$NioWorkerMetrics.<init>:(Lorg/xnio/nio/NioXnioWorker;Ljava/lang/String;)V
            putfield org.xnio.nio.NioXnioWorker.metrics:Lorg/xnio/nio/NioXnioWorker$NioWorkerMetrics;
        47: .line 129
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.metrics:Lorg/xnio/nio/NioXnioWorker$NioWorkerMetrics;
            invokevirtual org.xnio.nio.NioXnioWorker$NioWorkerMetrics.register:()V
        48: .line 130
            return
        end local 8 // boolean ok
        end local 7 // boolean markWorkerThreadAsDaemon
        end local 6 // java.lang.ThreadGroup threadGroup
        end local 5 // org.xnio.nio.WorkerThread[] workerThreads
        end local 4 // java.lang.String workerName
        end local 3 // int threadCount
        end local 2 // org.xnio.nio.NioXnio xnio
        end local 1 // org.xnio.XnioWorker$Builder builder
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0   49     0                      this  Lorg/xnio/nio/NioXnioWorker;
            0   49     1                   builder  Lorg/xnio/XnioWorker$Builder;
            3   49     2                      xnio  Lorg/xnio/nio/NioXnio;
            4   49     3               threadCount  I
            6   49     4                workerName  Ljava/lang/String;
            7   49     5             workerThreads  [Lorg/xnio/nio/WorkerThread;
            8   49     6               threadGroup  Ljava/lang/ThreadGroup;
            9   49     7  markWorkerThreadAsDaemon  Z
           10   49     8                        ok  Z
           11   22     9                         i  I
           13   14    10            threadSelector  Ljava/nio/channels/Selector;
           16   20    10            threadSelector  Ljava/nio/channels/Selector;
           15   16    11                         e  Ljava/io/IOException;
           17   20    11              workerThread  Lorg/xnio/nio/WorkerThread;
           23   24     9            threadSelector  Ljava/nio/channels/Selector;
           26   30     9            threadSelector  Ljava/nio/channels/Selector;
           25   26    10                         e  Ljava/io/IOException;
           35   36    13                    worker  Lorg/xnio/nio/WorkerThread;
           42   43    13                    worker  Lorg/xnio/nio/WorkerThread;
      Exception table:
        from    to  target  type
          12    13      14  Class java.io.IOException
          22    23      24  Class java.io.IOException
          10    31      31  any
    MethodParameters:
         Name  Flags
      builder  final

  void start();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=5, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 133
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerThreads:[Lorg/xnio/nio/WorkerThread;
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 5
      StackMap locals: org.xnio.nio.NioXnioWorker top int int org.xnio.nio.WorkerThread[]
      StackMap stack:
         1: aload 4
            iload 2
            aaload
            astore 1 /* worker */
        start local 1 // org.xnio.nio.WorkerThread worker
         2: .line 134
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.openResourceUnconditionally:()V
         3: .line 135
            aload 1 /* worker */
            invokevirtual org.xnio.nio.WorkerThread.start:()V
        end local 1 // org.xnio.nio.WorkerThread worker
         4: .line 133
            iinc 2 1
      StackMap locals:
      StackMap stack:
         5: iload 2
            iload 3
            if_icmplt 1
         6: .line 137
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.openResourceUnconditionally:()V
         7: .line 138
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.acceptThread:Lorg/xnio/nio/WorkerThread;
            invokevirtual org.xnio.nio.WorkerThread.start:()V
         8: .line 139
            return
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lorg/xnio/nio/NioXnioWorker;
            2    4     1  worker  Lorg/xnio/nio/WorkerThread;

  protected org.wildfly.common.net.CidrAddressTable<java.net.InetSocketAddress> getBindAddressTable();
    descriptor: ()Lorg/wildfly/common/net/CidrAddressTable;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 142
            aload 0 /* this */
            invokespecial org.xnio.XnioWorker.getBindAddressTable:()Lorg/wildfly/common/net/CidrAddressTable;
            areturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/NioXnioWorker;
    Signature: ()Lorg/wildfly/common/net/CidrAddressTable<Ljava/net/InetSocketAddress;>;

  protected org.xnio.nio.WorkerThread chooseThread();
    descriptor: ()Lorg/xnio/nio/WorkerThread;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 146
            aload 0 /* this */
            invokestatic java.util.concurrent.ThreadLocalRandom.current:()Ljava/util/concurrent/ThreadLocalRandom;
            invokevirtual java.util.concurrent.ThreadLocalRandom.nextInt:()I
            invokevirtual org.xnio.nio.NioXnioWorker.getIoThread:(I)Lorg/xnio/nio/WorkerThread;
            areturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/NioXnioWorker;

  public org.xnio.nio.WorkerThread getIoThread(int);
    descriptor: (I)Lorg/xnio/nio/WorkerThread;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.xnio.nio.NioXnioWorker this
        start local 1 // int hashCode
         0: .line 150
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerThreads:[Lorg/xnio/nio/WorkerThread;
            astore 2 /* workerThreads */
        start local 2 // org.xnio.nio.WorkerThread[] workerThreads
         1: .line 151
            aload 2 /* workerThreads */
            arraylength
            istore 3 /* length */
        start local 3 // int length
         2: .line 152
            iload 3 /* length */
            ifne 4
         3: .line 153
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            invokeinterface org.xnio.nio.Log.noThreads:()Ljava/lang/IllegalArgumentException;
            athrow
         4: .line 155
      StackMap locals: org.xnio.nio.WorkerThread[] int
      StackMap stack:
            iload 3 /* length */
            iconst_1
            if_icmpne 6
         5: .line 156
            aload 2 /* workerThreads */
            iconst_0
            aaload
            areturn
         6: .line 158
      StackMap locals:
      StackMap stack:
            aload 2 /* workerThreads */
            iload 1 /* hashCode */
            iload 3 /* length */
            irem
            invokestatic java.lang.Math.abs:(I)I
            aaload
            areturn
        end local 3 // int length
        end local 2 // org.xnio.nio.WorkerThread[] workerThreads
        end local 1 // int hashCode
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    7     0           this  Lorg/xnio/nio/NioXnioWorker;
            0    7     1       hashCode  I
            1    7     2  workerThreads  [Lorg/xnio/nio/WorkerThread;
            2    7     3         length  I
    MethodParameters:
          Name  Flags
      hashCode  final

  public int getIoThreadCount();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 162
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerThreads:[Lorg/xnio/nio/WorkerThread;
            arraylength
            ireturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/NioXnioWorker;

  org.xnio.nio.WorkerThread[] getAll();
    descriptor: ()[Lorg/xnio/nio/WorkerThread;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 166
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerThreads:[Lorg/xnio/nio/WorkerThread;
            areturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/NioXnioWorker;

  protected org.xnio.channels.AcceptingChannel<org.xnio.StreamConnection> createTcpConnectionServer(java.net.InetSocketAddress, org.xnio.ChannelListener<? super org.xnio.channels.AcceptingChannel<org.xnio.StreamConnection>>, org.xnio.OptionMap);
    descriptor: (Ljava/net/InetSocketAddress;Lorg/xnio/ChannelListener;Lorg/xnio/OptionMap;)Lorg/xnio/channels/AcceptingChannel;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=9, args_size=4
        start local 0 // org.xnio.nio.NioXnioWorker this
        start local 1 // java.net.InetSocketAddress bindAddress
        start local 2 // org.xnio.ChannelListener acceptListener
        start local 3 // org.xnio.OptionMap optionMap
         0: .line 170
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.checkShutdown:()V
         1: .line 171
            iconst_0
            istore 4 /* ok */
        start local 4 // boolean ok
         2: .line 172
            invokestatic java.nio.channels.ServerSocketChannel.open:()Ljava/nio/channels/ServerSocketChannel;
            astore 5 /* channel */
        start local 5 // java.nio.channels.ServerSocketChannel channel
         3: .line 174
            aload 3 /* optionMap */
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 4
            aload 5 /* channel */
            invokevirtual java.nio.channels.ServerSocketChannel.socket:()Ljava/net/ServerSocket;
            aload 3 /* optionMap */
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            iconst_m1
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            invokevirtual java.net.ServerSocket.setReceiveBufferSize:(I)V
         4: .line 175
      StackMap locals: int java.nio.channels.ServerSocketChannel
      StackMap stack:
            aload 5 /* channel */
            invokevirtual java.nio.channels.ServerSocketChannel.socket:()Ljava/net/ServerSocket;
            aload 3 /* optionMap */
            getstatic org.xnio.Options.REUSE_ADDRESSES:Lorg/xnio/Option;
            iconst_1
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;Z)Z
            invokevirtual java.net.ServerSocket.setReuseAddress:(Z)V
         5: .line 176
            aload 5 /* channel */
            iconst_0
            invokevirtual java.nio.channels.ServerSocketChannel.configureBlocking:(Z)Ljava/nio/channels/SelectableChannel;
            pop
         6: .line 177
            aload 3 /* optionMap */
            getstatic org.xnio.Options.BACKLOG:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 9
         7: .line 178
            aload 5 /* channel */
            invokevirtual java.nio.channels.ServerSocketChannel.socket:()Ljava/net/ServerSocket;
            aload 1 /* bindAddress */
            aload 3 /* optionMap */
            getstatic org.xnio.Options.BACKLOG:Lorg/xnio/Option;
            sipush 128
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            invokevirtual java.net.ServerSocket.bind:(Ljava/net/SocketAddress;I)V
         8: .line 179
            goto 10
         9: .line 180
      StackMap locals:
      StackMap stack:
            aload 5 /* channel */
            invokevirtual java.nio.channels.ServerSocketChannel.socket:()Ljava/net/ServerSocket;
            aload 1 /* bindAddress */
            invokevirtual java.net.ServerSocket.bind:(Ljava/net/SocketAddress;)V
        10: .line 188
      StackMap locals:
      StackMap stack:
            new org.xnio.nio.QueuedNioTcpServer
            dup
            aload 0 /* this */
            aload 5 /* channel */
            aload 3 /* optionMap */
            invokespecial org.xnio.nio.QueuedNioTcpServer.<init>:(Lorg/xnio/nio/NioXnioWorker;Ljava/nio/channels/ServerSocketChannel;Lorg/xnio/OptionMap;)V
            astore 6 /* server */
        start local 6 // org.xnio.nio.QueuedNioTcpServer server
        11: .line 189
            aload 6 /* server */
            aload 2 /* acceptListener */
            invokevirtual org.xnio.nio.QueuedNioTcpServer.setAcceptListener:(Lorg/xnio/ChannelListener;)V
        12: .line 190
            iconst_1
            istore 4 /* ok */
        13: .line 191
            aload 6 /* server */
            astore 8
        14: .line 194
            iload 4 /* ok */
            ifne 16
        15: .line 195
            aload 5 /* channel */
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
        16: .line 191
      StackMap locals: org.xnio.nio.NioXnioWorker java.net.InetSocketAddress org.xnio.ChannelListener org.xnio.OptionMap int java.nio.channels.ServerSocketChannel org.xnio.nio.QueuedNioTcpServer top org.xnio.channels.AcceptingChannel
      StackMap stack:
            aload 8
            areturn
        end local 6 // org.xnio.nio.QueuedNioTcpServer server
        17: .line 193
      StackMap locals: org.xnio.nio.NioXnioWorker java.net.InetSocketAddress org.xnio.ChannelListener org.xnio.OptionMap int java.nio.channels.ServerSocketChannel
      StackMap stack: java.lang.Throwable
            astore 7
        18: .line 194
            iload 4 /* ok */
            ifne 20
        19: .line 195
            aload 5 /* channel */
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
        20: .line 197
      StackMap locals: org.xnio.nio.NioXnioWorker java.net.InetSocketAddress org.xnio.ChannelListener org.xnio.OptionMap int java.nio.channels.ServerSocketChannel top java.lang.Throwable
      StackMap stack:
            aload 7
            athrow
        end local 5 // java.nio.channels.ServerSocketChannel channel
        end local 4 // boolean ok
        end local 3 // org.xnio.OptionMap optionMap
        end local 2 // org.xnio.ChannelListener acceptListener
        end local 1 // java.net.InetSocketAddress bindAddress
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   21     0            this  Lorg/xnio/nio/NioXnioWorker;
            0   21     1     bindAddress  Ljava/net/InetSocketAddress;
            0   21     2  acceptListener  Lorg/xnio/ChannelListener<-Lorg/xnio/channels/AcceptingChannel<Lorg/xnio/StreamConnection;>;>;
            0   21     3       optionMap  Lorg/xnio/OptionMap;
            2   21     4              ok  Z
            3   21     5         channel  Ljava/nio/channels/ServerSocketChannel;
           11   17     6          server  Lorg/xnio/nio/QueuedNioTcpServer;
      Exception table:
        from    to  target  type
           3    14      17  any
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/net/InetSocketAddress;Lorg/xnio/ChannelListener<-Lorg/xnio/channels/AcceptingChannel<Lorg/xnio/StreamConnection;>;>;Lorg/xnio/OptionMap;)Lorg/xnio/channels/AcceptingChannel<Lorg/xnio/StreamConnection;>;
    MethodParameters:
                Name  Flags
      bindAddress     final
      acceptListener  final
      optionMap       final

  public org.xnio.channels.MulticastMessageChannel createUdpServer(java.net.InetSocketAddress, org.xnio.ChannelListener<? super org.xnio.channels.MulticastMessageChannel>, org.xnio.OptionMap);
    descriptor: (Ljava/net/InetSocketAddress;Lorg/xnio/ChannelListener;Lorg/xnio/OptionMap;)Lorg/xnio/channels/MulticastMessageChannel;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // org.xnio.nio.NioXnioWorker this
        start local 1 // java.net.InetSocketAddress bindAddress
        start local 2 // org.xnio.ChannelListener bindListener
        start local 3 // org.xnio.OptionMap optionMap
         0: .line 203
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.checkShutdown:()V
         1: .line 205
            aload 1 /* bindAddress */
            ifnull 8
         2: .line 206
            aload 1 /* bindAddress */
            invokevirtual java.net.InetSocketAddress.getAddress:()Ljava/net/InetAddress;
            astore 5 /* address */
        start local 5 // java.net.InetAddress address
         3: .line 207
            aload 5 /* address */
            instanceof java.net.Inet6Address
            ifeq 6
         4: .line 208
            getstatic java.net.StandardProtocolFamily.INET6:Ljava/net/StandardProtocolFamily;
            invokestatic java.nio.channels.DatagramChannel.open:(Ljava/net/ProtocolFamily;)Ljava/nio/channels/DatagramChannel;
            astore 4 /* channel */
        start local 4 // java.nio.channels.DatagramChannel channel
         5: .line 209
            goto 9
        end local 4 // java.nio.channels.DatagramChannel channel
         6: .line 210
      StackMap locals: org.xnio.nio.NioXnioWorker java.net.InetSocketAddress org.xnio.ChannelListener org.xnio.OptionMap top java.net.InetAddress
      StackMap stack:
            getstatic java.net.StandardProtocolFamily.INET:Ljava/net/StandardProtocolFamily;
            invokestatic java.nio.channels.DatagramChannel.open:(Ljava/net/ProtocolFamily;)Ljava/nio/channels/DatagramChannel;
            astore 4 /* channel */
        end local 5 // java.net.InetAddress address
        start local 4 // java.nio.channels.DatagramChannel channel
         7: .line 212
            goto 9
        end local 4 // java.nio.channels.DatagramChannel channel
         8: .line 213
      StackMap locals: org.xnio.nio.NioXnioWorker java.net.InetSocketAddress org.xnio.ChannelListener org.xnio.OptionMap
      StackMap stack:
            invokestatic java.nio.channels.DatagramChannel.open:()Ljava/nio/channels/DatagramChannel;
            astore 4 /* channel */
        start local 4 // java.nio.channels.DatagramChannel channel
         9: .line 215
      StackMap locals: java.nio.channels.DatagramChannel
      StackMap stack:
            aload 4 /* channel */
            iconst_0
            invokevirtual java.nio.channels.DatagramChannel.configureBlocking:(Z)Ljava/nio/channels/SelectableChannel;
            pop
        10: .line 216
            aload 3 /* optionMap */
            getstatic org.xnio.Options.BROADCAST:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 11
            aload 4 /* channel */
            invokevirtual java.nio.channels.DatagramChannel.socket:()Ljava/net/DatagramSocket;
            aload 3 /* optionMap */
            getstatic org.xnio.Options.BROADCAST:Lorg/xnio/Option;
            iconst_0
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;Z)Z
            invokevirtual java.net.DatagramSocket.setBroadcast:(Z)V
        11: .line 217
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.IP_TRAFFIC_CLASS:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 12
            aload 4 /* channel */
            invokevirtual java.nio.channels.DatagramChannel.socket:()Ljava/net/DatagramSocket;
            aload 3 /* optionMap */
            getstatic org.xnio.Options.IP_TRAFFIC_CLASS:Lorg/xnio/Option;
            iconst_m1
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            invokevirtual java.net.DatagramSocket.setTrafficClass:(I)V
        12: .line 218
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 13
            aload 4 /* channel */
            invokevirtual java.nio.channels.DatagramChannel.socket:()Ljava/net/DatagramSocket;
            aload 3 /* optionMap */
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            iconst_m1
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            invokevirtual java.net.DatagramSocket.setReceiveBufferSize:(I)V
        13: .line 219
      StackMap locals:
      StackMap stack:
            aload 4 /* channel */
            invokevirtual java.nio.channels.DatagramChannel.socket:()Ljava/net/DatagramSocket;
            aload 3 /* optionMap */
            getstatic org.xnio.Options.REUSE_ADDRESSES:Lorg/xnio/Option;
            iconst_1
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;Z)Z
            invokevirtual java.net.DatagramSocket.setReuseAddress:(Z)V
        14: .line 220
            aload 3 /* optionMap */
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 15
            aload 4 /* channel */
            invokevirtual java.nio.channels.DatagramChannel.socket:()Ljava/net/DatagramSocket;
            aload 3 /* optionMap */
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            iconst_m1
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            invokevirtual java.net.DatagramSocket.setSendBufferSize:(I)V
        15: .line 221
      StackMap locals:
      StackMap stack:
            aload 4 /* channel */
            invokevirtual java.nio.channels.DatagramChannel.socket:()Ljava/net/DatagramSocket;
            aload 1 /* bindAddress */
            invokevirtual java.net.DatagramSocket.bind:(Ljava/net/SocketAddress;)V
        16: .line 222
            new org.xnio.nio.NioUdpChannel
            dup
            aload 0 /* this */
            aload 4 /* channel */
            invokespecial org.xnio.nio.NioUdpChannel.<init>:(Lorg/xnio/nio/NioXnioWorker;Ljava/nio/channels/DatagramChannel;)V
            astore 5 /* udpChannel */
        start local 5 // org.xnio.nio.NioUdpChannel udpChannel
        17: .line 223
            aload 5 /* udpChannel */
            aload 2 /* bindListener */
            invokestatic org.xnio.ChannelListeners.invokeChannelListener:(Ljava/nio/channels/Channel;Lorg/xnio/ChannelListener;)Z
            pop
        18: .line 224
            aload 5 /* udpChannel */
            areturn
        end local 5 // org.xnio.nio.NioUdpChannel udpChannel
        end local 4 // java.nio.channels.DatagramChannel channel
        end local 3 // org.xnio.OptionMap optionMap
        end local 2 // org.xnio.ChannelListener bindListener
        end local 1 // java.net.InetSocketAddress bindAddress
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   19     0          this  Lorg/xnio/nio/NioXnioWorker;
            0   19     1   bindAddress  Ljava/net/InetSocketAddress;
            0   19     2  bindListener  Lorg/xnio/ChannelListener<-Lorg/xnio/channels/MulticastMessageChannel;>;
            0   19     3     optionMap  Lorg/xnio/OptionMap;
            5    6     4       channel  Ljava/nio/channels/DatagramChannel;
            7    8     4       channel  Ljava/nio/channels/DatagramChannel;
            9   19     4       channel  Ljava/nio/channels/DatagramChannel;
            3    7     5       address  Ljava/net/InetAddress;
           17   19     5    udpChannel  Lorg/xnio/nio/NioUdpChannel;
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/net/InetSocketAddress;Lorg/xnio/ChannelListener<-Lorg/xnio/channels/MulticastMessageChannel;>;Lorg/xnio/OptionMap;)Lorg/xnio/channels/MulticastMessageChannel;
    MethodParameters:
              Name  Flags
      bindAddress   final
      bindListener  final
      optionMap     final

  public boolean isShutdown();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 228
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            ldc -2147483648
            iand
            ifeq 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/xnio/nio/NioXnioWorker;

  public boolean isTerminated();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 232
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            ldc 1073741824
            iand
            ifeq 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/xnio/nio/NioXnioWorker;

  void openResourceUnconditionally();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 239
            getstatic org.xnio.nio.NioXnioWorker.stateUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            istore 1 /* oldState */
        start local 1 // int oldState
         1: .line 240
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            invokeinterface org.xnio.nio.Log.isTraceEnabled:()Z
            ifeq 3
         2: .line 241
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "CAS %s %08x -> %08x"
            aload 0 /* this */
            iload 1 /* oldState */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            iload 1 /* oldState */
            iconst_1
            iadd
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.xnio.nio.Log.tracef:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 243
      StackMap locals: int
      StackMap stack:
            return
        end local 1 // int oldState
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lorg/xnio/nio/NioXnioWorker;
            1    4     1  oldState  I

  void checkShutdown();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 246
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.isShutdown:()Z
            ifeq 2
         1: .line 247
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            invokeinterface org.xnio.nio.Log.workerShutDown:()Lorg/xnio/ClosedWorkerException;
            athrow
         2: .line 248
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/xnio/nio/NioXnioWorker;
    Exceptions:
      throws org.xnio.ClosedWorkerException

  void closeResource();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 251
            getstatic org.xnio.nio.NioXnioWorker.stateUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            istore 1 /* oldState */
        start local 1 // int oldState
         1: .line 252
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            invokeinterface org.xnio.nio.Log.isTraceEnabled:()Z
            ifeq 14
         2: .line 253
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "CAS %s %08x -> %08x"
            aload 0 /* this */
            iload 1 /* oldState */
            iconst_1
            iadd
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            iload 1 /* oldState */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.xnio.nio.Log.tracef:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 255
            goto 14
         4: .line 256
      StackMap locals: int
      StackMap stack:
            getstatic org.xnio.nio.NioXnioWorker.stateUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            ldc -2147483648
            ldc -1073741824
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.compareAndSet:(Ljava/lang/Object;II)Z
            ifeq 13
         5: .line 257
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "CAS %s %08x -> %08x (close complete)"
            aload 0 /* this */
            ldc -2147483648
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            ldc -1073741824
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.xnio.nio.Log.tracef:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         6: .line 258
            getstatic org.xnio.nio.NioXnioWorker.shutdownWaiterUpdater:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aconst_null
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.getAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Thread
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
         7: .line 259
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.getTerminationTask:()Ljava/lang/Runnable;
            astore 2 /* task */
        start local 2 // java.lang.Runnable task
         8: .line 260
            aload 2 /* task */
            ifnull 12
         9: .line 261
            aload 2 /* task */
            invokeinterface java.lang.Runnable.run:()V
        10: .line 262
            goto 12
      StackMap locals: org.xnio.nio.NioXnioWorker int java.lang.Runnable
      StackMap stack: java.lang.Throwable
        11: pop
        12: .line 263
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Runnable task
        13: .line 265
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            istore 1 /* oldState */
        14: .line 255
      StackMap locals:
      StackMap stack:
            iload 1 /* oldState */
            ldc -2147483648
            if_icmpeq 4
        15: .line 267
            return
        end local 1 // int oldState
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   16     0      this  Lorg/xnio/nio/NioXnioWorker;
            1   16     1  oldState  I
            8   13     2      task  Ljava/lang/Runnable;
      Exception table:
        from    to  target  type
           9    10      11  Class java.lang.Throwable

  public void shutdown();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 271
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            istore 1 /* oldState */
        start local 1 // int oldState
         1: .line 272
            goto 14
         2: .line 274
      StackMap locals: int
      StackMap stack:
            getstatic org.xnio.nio.NioXnioWorker.stateUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 1 /* oldState */
            iload 1 /* oldState */
            ldc -2147483648
            ior
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.compareAndSet:(Ljava/lang/Object;II)Z
            ifne 5
         3: .line 276
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            istore 1 /* oldState */
         4: .line 277
            goto 14
         5: .line 279
      StackMap locals:
      StackMap stack:
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "Initiating shutdown of %s"
            aload 0 /* this */
            invokeinterface org.xnio.nio.Log.tracef:(Ljava/lang/String;Ljava/lang/Object;)V
         6: .line 280
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerThreads:[Lorg/xnio/nio/WorkerThread;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 10
      StackMap locals: org.xnio.nio.NioXnioWorker int top int int org.xnio.nio.WorkerThread[]
      StackMap stack:
         7: aload 5
            iload 3
            aaload
            astore 2 /* worker */
        start local 2 // org.xnio.nio.WorkerThread worker
         8: .line 281
            aload 2 /* worker */
            invokevirtual org.xnio.nio.WorkerThread.shutdown:()V
        end local 2 // org.xnio.nio.WorkerThread worker
         9: .line 280
            iinc 3 1
      StackMap locals:
      StackMap stack:
        10: iload 3
            iload 4
            if_icmplt 7
        11: .line 283
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.acceptThread:Lorg/xnio/nio/WorkerThread;
            invokevirtual org.xnio.nio.WorkerThread.shutdown:()V
        12: .line 284
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.shutDownTaskPool:()V
        13: .line 285
            return
        14: .line 272
      StackMap locals: org.xnio.nio.NioXnioWorker int
      StackMap stack:
            iload 1 /* oldState */
            ldc -2147483648
            iand
            ifeq 2
        15: .line 287
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "Idempotent shutdown of %s"
            aload 0 /* this */
            invokeinterface org.xnio.nio.Log.tracef:(Ljava/lang/String;Ljava/lang/Object;)V
        16: .line 288
            return
        end local 1 // int oldState
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   17     0      this  Lorg/xnio/nio/NioXnioWorker;
            1   17     1  oldState  I
            8    9     2    worker  Lorg/xnio/nio/WorkerThread;

  public java.util.List<java.lang.Runnable> shutdownNow();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 292
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.shutdown:()V
         1: .line 293
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.shutDownTaskPoolNow:()Ljava/util/List;
            areturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/xnio/nio/NioXnioWorker;
    Signature: ()Ljava/util/List<Ljava/lang/Runnable;>;

  public boolean awaitTermination(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=14, args_size=3
        start local 0 // org.xnio.nio.NioXnioWorker this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit unit
         0: .line 297
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            istore 4 /* oldState */
        start local 4 // int oldState
         1: .line 298
            iload 4 /* oldState */
            ldc 1073741824
            invokestatic org.xnio.Bits.allAreSet:(II)Z
            ifeq 3
         2: .line 299
            iconst_1
            ireturn
         3: .line 301
      StackMap locals: int
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 5 /* then */
        start local 5 // long then
         4: .line 302
            aload 3 /* unit */
            lload 1 /* timeout */
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lstore 7 /* duration */
        start local 7 // long duration
         5: .line 303
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 9 /* myThread */
        start local 9 // java.lang.Thread myThread
         6: .line 304
            goto 24
         7: .line 305
      StackMap locals: long long java.lang.Thread
      StackMap stack:
            getstatic org.xnio.nio.NioXnioWorker.shutdownWaiterUpdater:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 9 /* myThread */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.getAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Thread
            astore 10 /* oldThread */
        start local 10 // java.lang.Thread oldThread
         8: .line 307
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            dup
            istore 4 /* oldState */
            ldc 1073741824
            invokestatic org.xnio.Bits.allAreSet:(II)Z
            ifeq 11
         9: .line 321
            aload 10 /* oldThread */
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
        10: .line 308
            goto 25
        11: .line 310
      StackMap locals: java.lang.Thread
      StackMap stack:
            aload 0 /* this */
            lload 7 /* duration */
            invokestatic java.util.concurrent.locks.LockSupport.parkNanos:(Ljava/lang/Object;J)V
        12: .line 311
            invokestatic java.lang.Thread.interrupted:()Z
            ifeq 14
        13: .line 312
            new java.lang.InterruptedException
            dup
            invokespecial java.lang.InterruptedException.<init>:()V
            athrow
        14: .line 314
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 11 /* now */
        start local 11 // long now
        15: .line 315
            lload 7 /* duration */
            lload 11 /* now */
            lload 5 /* then */
            lsub
            lsub
            lstore 7 /* duration */
        16: .line 316
            lload 7 /* duration */
            lconst_0
            lcmp
            ifge 23
        17: .line 317
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            istore 4 /* oldState */
        18: .line 321
            aload 10 /* oldThread */
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
        19: .line 318
            goto 25
        end local 11 // long now
        20: .line 320
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 13
        21: .line 321
            aload 10 /* oldThread */
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
        22: .line 322
            aload 13
            athrow
        23: .line 321
      StackMap locals:
      StackMap stack:
            aload 10 /* oldThread */
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
        end local 10 // java.lang.Thread oldThread
        24: .line 304
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            dup
            istore 4 /* oldState */
            ldc 1073741824
            invokestatic org.xnio.Bits.allAreClear:(II)Z
            ifne 7
        25: .line 324
      StackMap locals:
      StackMap stack:
            iload 4 /* oldState */
            ldc 1073741824
            invokestatic org.xnio.Bits.allAreSet:(II)Z
            ireturn
        end local 9 // java.lang.Thread myThread
        end local 7 // long duration
        end local 5 // long then
        end local 4 // int oldState
        end local 3 // java.util.concurrent.TimeUnit unit
        end local 1 // long timeout
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   26     0       this  Lorg/xnio/nio/NioXnioWorker;
            0   26     1    timeout  J
            0   26     3       unit  Ljava/util/concurrent/TimeUnit;
            1   26     4   oldState  I
            4   26     5       then  J
            5   26     7   duration  J
            6   26     9   myThread  Ljava/lang/Thread;
            8   24    10  oldThread  Ljava/lang/Thread;
           15   20    11        now  J
      Exception table:
        from    to  target  type
           8     9      20  any
          11    18      20  any
    Exceptions:
      throws java.lang.InterruptedException
    MethodParameters:
         Name  Flags
      timeout  final
      unit     final

  public void awaitTermination();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 328
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            istore 1 /* oldState */
        start local 1 // int oldState
         1: .line 329
            iload 1 /* oldState */
            ldc 1073741824
            invokestatic org.xnio.Bits.allAreSet:(II)Z
            ifeq 3
         2: .line 330
            return
         3: .line 332
      StackMap locals: int
      StackMap stack:
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            astore 2 /* myThread */
        start local 2 // java.lang.Thread myThread
         4: .line 333
            goto 16
         5: .line 334
      StackMap locals: java.lang.Thread
      StackMap stack:
            getstatic org.xnio.nio.NioXnioWorker.shutdownWaiterUpdater:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 2 /* myThread */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.getAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Thread
            astore 3 /* oldThread */
        start local 3 // java.lang.Thread oldThread
         6: .line 336
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            ldc 1073741824
            invokestatic org.xnio.Bits.allAreSet:(II)Z
            ifeq 9
         7: .line 344
            aload 3 /* oldThread */
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
         8: .line 337
            goto 17
         9: .line 339
      StackMap locals: java.lang.Thread
      StackMap stack:
            aload 0 /* this */
            invokestatic java.util.concurrent.locks.LockSupport.park:(Ljava/lang/Object;)V
        10: .line 340
            invokestatic java.lang.Thread.interrupted:()Z
            ifeq 15
        11: .line 341
            new java.lang.InterruptedException
            dup
            invokespecial java.lang.InterruptedException.<init>:()V
            athrow
        12: .line 343
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 4
        13: .line 344
            aload 3 /* oldThread */
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
        14: .line 345
            aload 4
            athrow
        15: .line 344
      StackMap locals:
      StackMap stack:
            aload 3 /* oldThread */
            invokestatic org.xnio.nio.NioXnioWorker.safeUnpark:(Ljava/lang/Thread;)V
        end local 3 // java.lang.Thread oldThread
        16: .line 333
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.state:I
            ldc 1073741824
            invokestatic org.xnio.Bits.allAreClear:(II)Z
            ifne 5
        17: .line 347
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Thread myThread
        end local 1 // int oldState
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   18     0       this  Lorg/xnio/nio/NioXnioWorker;
            1   18     1   oldState  I
            4   18     2   myThread  Ljava/lang/Thread;
            6   16     3  oldThread  Ljava/lang/Thread;
      Exception table:
        from    to  target  type
           6     7      12  any
           9    12      12  any
    Exceptions:
      throws java.lang.InterruptedException

  private static void safeUnpark(java.lang.Thread);
    descriptor: (Ljava/lang/Thread;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.lang.Thread waiter
         0: .line 350
            aload 0 /* waiter */
            ifnull 1
            aload 0 /* waiter */
            invokestatic java.util.concurrent.locks.LockSupport.unpark:(Ljava/lang/Thread;)V
         1: .line 351
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.lang.Thread waiter
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0  waiter  Ljava/lang/Thread;
    MethodParameters:
        Name  Flags
      waiter  final

  protected void taskPoolTerminated();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 354
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.metrics:Lorg/xnio/nio/NioXnioWorker$NioWorkerMetrics;
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
         1: .line 355
            aload 0 /* this */
            invokevirtual org.xnio.nio.NioXnioWorker.closeResource:()V
         2: .line 356
            return
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/xnio/nio/NioXnioWorker;

  public <T> T getOption(org.xnio.Option<T>);
    descriptor: (Lorg/xnio/Option;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.xnio.nio.NioXnioWorker this
        start local 1 // org.xnio.Option option
         0: .line 360
            aload 1 /* option */
            getstatic org.xnio.Options.WORKER_IO_THREADS:Lorg/xnio/Option;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 2
         1: .line 361
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerThreads:[Lorg/xnio/nio/WorkerThread;
            arraylength
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
         2: .line 362
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.STACK_SIZE:Lorg/xnio/Option;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 363
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.workerStackSize:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
         4: .line 365
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* option */
            invokespecial org.xnio.XnioWorker.getOption:(Lorg/xnio/Option;)Ljava/lang/Object;
            areturn
        end local 1 // org.xnio.Option option
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/xnio/nio/NioXnioWorker;
            0    5     1  option  Lorg/xnio/Option<TT;>;
    Exceptions:
      throws java.io.IOException
    Signature: <T:Ljava/lang/Object;>(Lorg/xnio/Option<TT;>;)TT;
    MethodParameters:
        Name  Flags
      option  

  public org.xnio.nio.NioXnio getXnio();
    descriptor: ()Lorg/xnio/nio/NioXnio;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 370
            aload 0 /* this */
            invokespecial org.xnio.XnioWorker.getXnio:()Lorg/xnio/Xnio;
            checkcast org.xnio.nio.NioXnio
            areturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/NioXnioWorker;

  org.xnio.nio.WorkerThread getAcceptThread();
    descriptor: ()Lorg/xnio/nio/WorkerThread;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 374
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.acceptThread:Lorg/xnio/nio/WorkerThread;
            areturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/NioXnioWorker;

  public org.xnio.management.XnioWorkerMXBean getMXBean();
    descriptor: ()Lorg/xnio/management/XnioWorkerMXBean;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.NioXnioWorker this
         0: .line 379
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.metrics:Lorg/xnio/nio/NioXnioWorker$NioWorkerMetrics;
            areturn
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/NioXnioWorker;

  protected org.xnio.ManagementRegistration registerServerMXBean(org.xnio.management.XnioServerMXBean);
    descriptor: (Lorg/xnio/management/XnioServerMXBean;)Lorg/xnio/ManagementRegistration;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.xnio.nio.NioXnioWorker this
        start local 1 // org.xnio.management.XnioServerMXBean serverMXBean
         0: .line 384
            aload 0 /* this */
            getfield org.xnio.nio.NioXnioWorker.metrics:Lorg/xnio/nio/NioXnioWorker$NioWorkerMetrics;
            aload 1 /* serverMXBean */
            invokevirtual org.xnio.nio.NioXnioWorker$NioWorkerMetrics.registerServerMXBean:(Lorg/xnio/management/XnioServerMXBean;)Lorg/xnio/ManagementRegistration;
            areturn
        end local 1 // org.xnio.management.XnioServerMXBean serverMXBean
        end local 0 // org.xnio.nio.NioXnioWorker this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lorg/xnio/nio/NioXnioWorker;
            0    1     1  serverMXBean  Lorg/xnio/management/XnioServerMXBean;
    MethodParameters:
              Name  Flags
      serverMXBean  

  protected org.xnio.XnioIoThread chooseThread();
    descriptor: ()Lorg/xnio/XnioIoThread;
    flags: (0x1044) ACC_PROTECTED, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.NioXnioWorker.chooseThread:()Lorg/xnio/nio/WorkerThread;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.xnio.XnioIoThread getIoThread(int);
    descriptor: (I)Lorg/xnio/XnioIoThread;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            iload 1
            invokevirtual org.xnio.nio.NioXnioWorker.getIoThread:(I)Lorg/xnio/nio/WorkerThread;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.xnio.Xnio getXnio();
    descriptor: ()Lorg/xnio/Xnio;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.NioXnioWorker.getXnio:()Lorg/xnio/nio/NioXnio;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static int access$3(org.xnio.nio.NioXnioWorker);
    descriptor: (Lorg/xnio/nio/NioXnioWorker;)I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.NioXnioWorker.getCoreWorkerPoolSize:()I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static int access$4(org.xnio.nio.NioXnioWorker);
    descriptor: (Lorg/xnio/nio/NioXnioWorker;)I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.NioXnioWorker.getMaxWorkerPoolSize:()I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static int access$5(org.xnio.nio.NioXnioWorker);
    descriptor: (Lorg/xnio/nio/NioXnioWorker;)I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.NioXnioWorker.getBusyWorkerThreadCount:()I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static int access$6(org.xnio.nio.NioXnioWorker);
    descriptor: (Lorg/xnio/nio/NioXnioWorker;)I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.NioXnioWorker.getWorkerQueueSize:()I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "NioXnioWorker.java"
NestMembers:
  org.xnio.nio.NioXnioWorker$NioWorkerMetrics
InnerClasses:
  public Builder = org.xnio.XnioWorker$Builder of org.xnio.XnioWorker
  abstract SelectorCreator = org.xnio.nio.NioXnio$SelectorCreator of org.xnio.nio.NioXnio
  private NioWorkerMetrics = org.xnio.nio.NioXnioWorker$NioWorkerMetrics of org.xnio.nio.NioXnioWorker