final class java.util.concurrent.CountDownLatch$Sync extends java.util.concurrent.locks.AbstractQueuedSynchronizer
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: java.util.concurrent.CountDownLatch$Sync
  super_class: java.util.concurrent.locks.AbstractQueuedSynchronizer
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 4982264981922014374

  void <init>(int);
    descriptor: (I)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.concurrent.CountDownLatch$Sync this
        start local 1 // int count
         0: .line 165
            aload 0 /* this */
            invokespecial java.util.concurrent.locks.AbstractQueuedSynchronizer.<init>:()V
         1: .line 166
            aload 0 /* this */
            iload 1 /* count */
            invokevirtual java.util.concurrent.CountDownLatch$Sync.setState:(I)V
         2: .line 167
            return
        end local 1 // int count
        end local 0 // java.util.concurrent.CountDownLatch$Sync this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Ljava/util/concurrent/CountDownLatch$Sync;
            0    3     1  count  I
    MethodParameters:
       Name  Flags
      count  

  int getCount();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.concurrent.CountDownLatch$Sync this
         0: .line 170
            aload 0 /* this */
            invokevirtual java.util.concurrent.CountDownLatch$Sync.getState:()I
            ireturn
        end local 0 // java.util.concurrent.CountDownLatch$Sync this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/concurrent/CountDownLatch$Sync;

  protected int tryAcquireShared(int);
    descriptor: (I)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // java.util.concurrent.CountDownLatch$Sync this
        start local 1 // int acquires
         0: .line 174
            aload 0 /* this */
            invokevirtual java.util.concurrent.CountDownLatch$Sync.getState:()I
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_m1
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 1 // int acquires
        end local 0 // java.util.concurrent.CountDownLatch$Sync this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Ljava/util/concurrent/CountDownLatch$Sync;
            0    3     1  acquires  I
    MethodParameters:
          Name  Flags
      acquires  

  protected boolean tryReleaseShared(int);
    descriptor: (I)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // java.util.concurrent.CountDownLatch$Sync this
        start local 1 // int releases
         0: .line 180
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.CountDownLatch$Sync.getState:()I
            istore 2 /* c */
        start local 2 // int c
         1: .line 181
            iload 2 /* c */
            ifne 3
         2: .line 182
            iconst_0
            ireturn
         3: .line 183
      StackMap locals: int
      StackMap stack:
            iload 2 /* c */
            iconst_1
            isub
            istore 3 /* nextc */
        start local 3 // int nextc
         4: .line 184
            aload 0 /* this */
            iload 2 /* c */
            iload 3 /* nextc */
            invokevirtual java.util.concurrent.CountDownLatch$Sync.compareAndSetState:(II)Z
            ifeq 0
         5: .line 185
            iload 3 /* nextc */
            ifne 6
            iconst_1
            ireturn
      StackMap locals: int
      StackMap stack:
         6: iconst_0
            ireturn
        end local 3 // int nextc
        end local 2 // int c
        end local 1 // int releases
        end local 0 // java.util.concurrent.CountDownLatch$Sync this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Ljava/util/concurrent/CountDownLatch$Sync;
            0    7     1  releases  I
            1    7     2         c  I
            4    7     3     nextc  I
    MethodParameters:
          Name  Flags
      releases  
}
SourceFile: "CountDownLatch.java"
NestHost: java.util.concurrent.CountDownLatch
InnerClasses:
  private final Sync = java.util.concurrent.CountDownLatch$Sync of java.util.concurrent.CountDownLatch