final class io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber<T> extends io.reactivex.internal.operators.parallel.ParallelRunOn$BaseRunOnSubscriber<T>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber
  super_class: io.reactivex.internal.operators.parallel.ParallelRunOn$BaseRunOnSubscriber
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1075119423897941642

  final org.reactivestreams.Subscriber<? super T> downstream;
    descriptor: Lorg/reactivestreams/Subscriber;
    flags: (0x0010) ACC_FINAL
    Signature: Lorg/reactivestreams/Subscriber<-TT;>;

  void <init>(org.reactivestreams.Subscriber<? super T>, int, io.reactivex.internal.queue.SpscArrayQueue<T>, io.reactivex.Scheduler$Worker);
    descriptor: (Lorg/reactivestreams/Subscriber;ILio/reactivex/internal/queue/SpscArrayQueue;Lio/reactivex/Scheduler$Worker;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber this
        start local 1 // org.reactivestreams.Subscriber actual
        start local 2 // int prefetch
        start local 3 // io.reactivex.internal.queue.SpscArrayQueue queue
        start local 4 // io.reactivex.Scheduler$Worker worker
         0: .line 210
            aload 0 /* this */
            iload 2 /* prefetch */
            aload 3 /* queue */
            aload 4 /* worker */
            invokespecial io.reactivex.internal.operators.parallel.ParallelRunOn$BaseRunOnSubscriber.<init>:(ILio/reactivex/internal/queue/SpscArrayQueue;Lio/reactivex/Scheduler$Worker;)V
         1: .line 211
            aload 0 /* this */
            aload 1 /* actual */
            putfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.downstream:Lorg/reactivestreams/Subscriber;
         2: .line 212
            return
        end local 4 // io.reactivex.Scheduler$Worker worker
        end local 3 // io.reactivex.internal.queue.SpscArrayQueue queue
        end local 2 // int prefetch
        end local 1 // org.reactivestreams.Subscriber actual
        end local 0 // io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lio/reactivex/internal/operators/parallel/ParallelRunOn$RunOnSubscriber<TT;>;
            0    3     1    actual  Lorg/reactivestreams/Subscriber<-TT;>;
            0    3     2  prefetch  I
            0    3     3     queue  Lio/reactivex/internal/queue/SpscArrayQueue<TT;>;
            0    3     4    worker  Lio/reactivex/Scheduler$Worker;
    Signature: (Lorg/reactivestreams/Subscriber<-TT;>;ILio/reactivex/internal/queue/SpscArrayQueue<TT;>;Lio/reactivex/Scheduler$Worker;)V
    MethodParameters:
          Name  Flags
      actual    
      prefetch  
      queue     
      worker    

  public void onSubscribe(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 216
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.upstream:Lorg/reactivestreams/Subscription;
            aload 1 /* s */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
            ifeq 4
         1: .line 217
            aload 0 /* this */
            aload 1 /* s */
            putfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.upstream:Lorg/reactivestreams/Subscription;
         2: .line 219
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 0 /* this */
            invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         3: .line 221
            aload 1 /* s */
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.prefetch:I
            i2l
            invokeinterface org.reactivestreams.Subscription.request:(J)V
         4: .line 223
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/parallel/ParallelRunOn$RunOnSubscriber<TT;>;
            0    5     1     s  Lorg/reactivestreams/Subscription;
    MethodParameters:
      Name  Flags
      s     

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=14, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber this
         0: .line 227
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 228
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.consumed:I
            istore 2 /* c */
        start local 2 // int c
         2: .line 229
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.queue:Lio/reactivex/internal/queue/SpscArrayQueue;
            astore 3 /* q */
        start local 3 // io.reactivex.internal.queue.SpscArrayQueue q
         3: .line 230
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            astore 4 /* a */
        start local 4 // org.reactivestreams.Subscriber a
         4: .line 231
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.limit:I
            istore 5 /* lim */
        start local 5 // int lim
         5: .line 235
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber int int io.reactivex.internal.queue.SpscArrayQueue org.reactivestreams.Subscriber int
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lstore 6 /* r */
        start local 6 // long r
         6: .line 236
            lconst_0
            lstore 8 /* e */
        start local 8 // long e
         7: .line 238
            goto 35
         8: .line 239
      StackMap locals: long long
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.cancelled:Z
            ifeq 11
         9: .line 240
            aload 3 /* q */
            invokevirtual io.reactivex.internal.queue.SpscArrayQueue.clear:()V
        10: .line 241
            return
        11: .line 244
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.done:Z
            istore 10 /* d */
        start local 10 // boolean d
        12: .line 246
            iload 10 /* d */
            ifeq 19
        13: .line 247
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.error:Ljava/lang/Throwable;
            astore 11 /* ex */
        start local 11 // java.lang.Throwable ex
        14: .line 248
            aload 11 /* ex */
            ifnull 19
        15: .line 249
            aload 3 /* q */
            invokevirtual io.reactivex.internal.queue.SpscArrayQueue.clear:()V
        16: .line 251
            aload 4 /* a */
            aload 11 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        17: .line 253
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
        18: .line 254
            return
        end local 11 // java.lang.Throwable ex
        19: .line 258
      StackMap locals: int
      StackMap stack:
            aload 3 /* q */
            invokevirtual io.reactivex.internal.queue.SpscArrayQueue.poll:()Ljava/lang/Object;
            astore 11 /* v */
        start local 11 // java.lang.Object v
        20: .line 260
            aload 11 /* v */
            ifnonnull 21
            iconst_1
            goto 22
      StackMap locals: java.lang.Object
      StackMap stack:
        21: iconst_0
      StackMap locals:
      StackMap stack: int
        22: istore 12 /* empty */
        start local 12 // boolean empty
        23: .line 262
            iload 10 /* d */
            ifeq 27
            iload 12 /* empty */
            ifeq 27
        24: .line 263
            aload 4 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        25: .line 265
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
        26: .line 266
            return
        27: .line 269
      StackMap locals: int
      StackMap stack:
            iload 12 /* empty */
            ifeq 29
        28: .line 270
            goto 36
        29: .line 273
      StackMap locals:
      StackMap stack:
            aload 4 /* a */
            aload 11 /* v */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        30: .line 275
            lload 8 /* e */
            lconst_1
            ladd
            lstore 8 /* e */
        31: .line 277
            iinc 2 /* c */ 1
            iload 2 /* c */
            istore 13 /* p */
        start local 13 // int p
        32: .line 278
            iload 13 /* p */
            iload 5 /* lim */
            if_icmpne 35
        33: .line 279
            iconst_0
            istore 2 /* c */
        34: .line 280
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.upstream:Lorg/reactivestreams/Subscription;
            iload 13 /* p */
            i2l
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        end local 13 // int p
        end local 12 // boolean empty
        end local 11 // java.lang.Object v
        end local 10 // boolean d
        35: .line 238
      StackMap locals:
      StackMap stack:
            lload 8 /* e */
            lload 6 /* r */
            lcmp
            ifne 8
        36: .line 284
      StackMap locals:
      StackMap stack:
            lload 8 /* e */
            lload 6 /* r */
            lcmp
            ifne 51
        37: .line 285
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.cancelled:Z
            ifeq 40
        38: .line 286
            aload 3 /* q */
            invokevirtual io.reactivex.internal.queue.SpscArrayQueue.clear:()V
        39: .line 287
            return
        40: .line 290
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.done:Z
            ifeq 51
        41: .line 291
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.error:Ljava/lang/Throwable;
            astore 10 /* ex */
        start local 10 // java.lang.Throwable ex
        42: .line 292
            aload 10 /* ex */
            ifnull 47
        43: .line 293
            aload 3 /* q */
            invokevirtual io.reactivex.internal.queue.SpscArrayQueue.clear:()V
        44: .line 295
            aload 4 /* a */
            aload 10 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        45: .line 297
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
        46: .line 298
            return
        47: .line 300
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3 /* q */
            invokevirtual io.reactivex.internal.queue.SpscArrayQueue.isEmpty:()Z
            ifeq 51
        48: .line 301
            aload 4 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        49: .line 303
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
        50: .line 304
            return
        end local 10 // java.lang.Throwable ex
        51: .line 309
      StackMap locals:
      StackMap stack:
            lload 8 /* e */
            lconst_0
            lcmp
            ifeq 53
            lload 6 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 53
        52: .line 310
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 8 /* e */
            lneg
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            pop2
        53: .line 313
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.get:()I
            istore 10 /* w */
        start local 10 // int w
        54: .line 314
            iload 10 /* w */
            iload 1 /* missed */
            if_icmpne 59
        55: .line 315
            aload 0 /* this */
            iload 2 /* c */
            putfield io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.consumed:I
        56: .line 316
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber.addAndGet:(I)I
            istore 1 /* missed */
        57: .line 317
            iload 1 /* missed */
            ifne 5
        58: .line 318
            goto 61
        59: .line 321
      StackMap locals: int
      StackMap stack:
            iload 10 /* w */
            istore 1 /* missed */
        end local 10 // int w
        end local 8 // long e
        end local 6 // long r
        60: .line 233
            goto 5
        61: .line 324
      StackMap locals:
      StackMap stack:
            return
        end local 5 // int lim
        end local 4 // org.reactivestreams.Subscriber a
        end local 3 // io.reactivex.internal.queue.SpscArrayQueue q
        end local 2 // int c
        end local 1 // int missed
        end local 0 // io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   62     0    this  Lio/reactivex/internal/operators/parallel/ParallelRunOn$RunOnSubscriber<TT;>;
            1   62     1  missed  I
            2   62     2       c  I
            3   62     3       q  Lio/reactivex/internal/queue/SpscArrayQueue<TT;>;
            4   62     4       a  Lorg/reactivestreams/Subscriber<-TT;>;
            5   62     5     lim  I
            6   60     6       r  J
            7   60     8       e  J
           12   35    10       d  Z
           14   19    11      ex  Ljava/lang/Throwable;
           20   35    11       v  TT;
           23   35    12   empty  Z
           32   35    13       p  I
           42   51    10      ex  Ljava/lang/Throwable;
           54   60    10       w  I
}
Signature: <T:Ljava/lang/Object;>Lio/reactivex/internal/operators/parallel/ParallelRunOn$BaseRunOnSubscriber<TT;>;
SourceFile: "ParallelRunOn.java"
NestHost: io.reactivex.internal.operators.parallel.ParallelRunOn
InnerClasses:
  public abstract Worker = io.reactivex.Scheduler$Worker of io.reactivex.Scheduler
  abstract BaseRunOnSubscriber = io.reactivex.internal.operators.parallel.ParallelRunOn$BaseRunOnSubscriber of io.reactivex.internal.operators.parallel.ParallelRunOn
  final RunOnSubscriber = io.reactivex.internal.operators.parallel.ParallelRunOn$RunOnSubscriber of io.reactivex.internal.operators.parallel.ParallelRunOn