final class io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber<T> extends java.util.concurrent.atomic.AtomicReference<java.lang.Thread> implements io.reactivex.FlowableSubscriber<T>, org.reactivestreams.Subscription, java.lang.Runnable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber
  super_class: java.util.concurrent.atomic.AtomicReference
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 8094547886072529208

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

  final io.reactivex.Scheduler$Worker worker;
    descriptor: Lio/reactivex/Scheduler$Worker;
    flags: (0x0010) ACC_FINAL

  final java.util.concurrent.atomic.AtomicReference<org.reactivestreams.Subscription> upstream;
    descriptor: Ljava/util/concurrent/atomic/AtomicReference;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/reactivestreams/Subscription;>;

  final java.util.concurrent.atomic.AtomicLong requested;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0010) ACC_FINAL

  final boolean nonScheduledRequests;
    descriptor: Z
    flags: (0x0010) ACC_FINAL

  org.reactivestreams.Publisher<T> source;
    descriptor: Lorg/reactivestreams/Publisher;
    flags: (0x0000) 
    Signature: Lorg/reactivestreams/Publisher<TT;>;

  void <init>(org.reactivestreams.Subscriber<? super T>, io.reactivex.Scheduler$Worker, org.reactivestreams.Publisher<T>, );
    descriptor: (Lorg/reactivestreams/Subscriber;Lio/reactivex/Scheduler$Worker;Lorg/reactivestreams/Publisher;Z)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
        start local 1 // org.reactivestreams.Subscriber actual
        start local 2 // io.reactivex.Scheduler$Worker worker
        start local 3 // org.reactivestreams.Publisher source
        start local 4 // boolean requestOn
         0: .line 68
            aload 0 /* this */
            invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
         1: .line 69
            aload 0 /* this */
            aload 1 /* actual */
            putfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.downstream:Lorg/reactivestreams/Subscriber;
         2: .line 70
            aload 0 /* this */
            aload 2 /* worker */
            putfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
         3: .line 71
            aload 0 /* this */
            aload 3 /* source */
            putfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.source:Lorg/reactivestreams/Publisher;
         4: .line 72
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicReference
            dup
            invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
         5: .line 73
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
         6: .line 74
            aload 0 /* this */
            iload 4 /* requestOn */
            ifeq 7
            iconst_0
            goto 8
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber org.reactivestreams.Subscriber io.reactivex.Scheduler$Worker org.reactivestreams.Publisher int
      StackMap stack: io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber
         7: iconst_1
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber org.reactivestreams.Subscriber io.reactivex.Scheduler$Worker org.reactivestreams.Publisher int
      StackMap stack: io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber int
         8: putfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.nonScheduledRequests:Z
         9: .line 75
            return
        end local 4 // boolean requestOn
        end local 3 // org.reactivestreams.Publisher source
        end local 2 // io.reactivex.Scheduler$Worker worker
        end local 1 // org.reactivestreams.Subscriber actual
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   10     0       this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
            0   10     1     actual  Lorg/reactivestreams/Subscriber<-TT;>;
            0   10     2     worker  Lio/reactivex/Scheduler$Worker;
            0   10     3     source  Lorg/reactivestreams/Publisher<TT;>;
            0   10     4  requestOn  Z
    Signature: (Lorg/reactivestreams/Subscriber<-TT;>;Lio/reactivex/Scheduler$Worker;Lorg/reactivestreams/Publisher<TT;>;Z)V
    MethodParameters:
           Name  Flags
      actual     
      worker     
      source     
      requestOn  

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
         0: .line 79
            aload 0 /* this */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.lazySet:(Ljava/lang/Object;)V
         1: .line 80
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.source:Lorg/reactivestreams/Publisher;
            astore 1 /* src */
        start local 1 // org.reactivestreams.Publisher src
         2: .line 81
            aload 0 /* this */
            aconst_null
            putfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.source:Lorg/reactivestreams/Publisher;
         3: .line 82
            aload 1 /* src */
            aload 0 /* this */
            invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
         4: .line 83
            return
        end local 1 // org.reactivestreams.Publisher src
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
            2    5     1   src  Lorg/reactivestreams/Publisher<TT;>;

  public void onSubscribe(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 87
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            aload 1 /* s */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.setOnce:(Ljava/util/concurrent/atomic/AtomicReference;Lorg/reactivestreams/Subscription;)Z
            ifeq 4
         1: .line 88
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lconst_0
            invokevirtual java.util.concurrent.atomic.AtomicLong.getAndSet:(J)J
            lstore 2 /* r */
        start local 2 // long r
         2: .line 89
            lload 2 /* r */
            lconst_0
            lcmp
            ifeq 4
         3: .line 90
            aload 0 /* this */
            lload 2 /* r */
            aload 1 /* s */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.requestUpstream:(JLorg/reactivestreams/Subscription;)V
        end local 2 // long r
         4: .line 93
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
            0    5     1     s  Lorg/reactivestreams/Subscription;
            2    4     2     r  J
    MethodParameters:
      Name  Flags
      s     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
        start local 1 // java.lang.Object t
         0: .line 97
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 1 /* t */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
         1: .line 98
            return
        end local 1 // java.lang.Object t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
            0    2     1     t  TT;
    Signature: (TT;)V
    MethodParameters:
      Name  Flags
      t     

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 102
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 1 /* t */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         1: .line 103
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         2: .line 104
            return
        end local 1 // java.lang.Throwable t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
            0    3     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
         0: .line 108
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
         1: .line 109
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         2: .line 110
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
        start local 1 // long n
         0: .line 114
            lload 1 /* n */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(J)Z
            ifeq 11
         1: .line 115
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.reactivestreams.Subscription
            astore 3 /* s */
        start local 3 // org.reactivestreams.Subscription s
         2: .line 116
            aload 3 /* s */
            ifnull 5
         3: .line 117
            aload 0 /* this */
            lload 1 /* n */
            aload 3 /* s */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.requestUpstream:(JLorg/reactivestreams/Subscription;)V
         4: .line 118
            goto 11
         5: .line 119
      StackMap locals: org.reactivestreams.Subscription
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 1 /* n */
            invokestatic io.reactivex.internal.util.BackpressureHelper.add:(Ljava/util/concurrent/atomic/AtomicLong;J)J
            pop2
         6: .line 120
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast org.reactivestreams.Subscription
            astore 3 /* s */
         7: .line 121
            aload 3 /* s */
            ifnull 11
         8: .line 122
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lconst_0
            invokevirtual java.util.concurrent.atomic.AtomicLong.getAndSet:(J)J
            lstore 4 /* r */
        start local 4 // long r
         9: .line 123
            lload 4 /* r */
            lconst_0
            lcmp
            ifeq 11
        10: .line 124
            aload 0 /* this */
            lload 4 /* r */
            aload 3 /* s */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.requestUpstream:(JLorg/reactivestreams/Subscription;)V
        end local 4 // long r
        end local 3 // org.reactivestreams.Subscription s
        11: .line 129
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
            0   12     1     n  J
            2   11     3     s  Lorg/reactivestreams/Subscription;
            9   11     4     r  J
    MethodParameters:
      Name  Flags
      n     final

  void requestUpstream(long, org.reactivestreams.Subscription);
    descriptor: (JLorg/reactivestreams/Subscription;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
        start local 1 // long n
        start local 3 // org.reactivestreams.Subscription s
         0: .line 132
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.nonScheduledRequests:Z
            ifne 1
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.get:()Ljava/lang/Object;
            if_acmpne 3
         1: .line 133
      StackMap locals:
      StackMap stack:
            aload 3 /* s */
            lload 1 /* n */
            invokeinterface org.reactivestreams.Subscription.request:(J)V
         2: .line 134
            goto 4
         3: .line 135
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            new io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber$Request
            dup
            aload 3 /* s */
            lload 1 /* n */
            invokespecial io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber$Request.<init>:(Lorg/reactivestreams/Subscription;J)V
            invokevirtual io.reactivex.Scheduler$Worker.schedule:(Ljava/lang/Runnable;)Lio/reactivex/disposables/Disposable;
            pop
         4: .line 137
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.reactivestreams.Subscription s
        end local 1 // long n
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
            0    5     1     n  J
            0    5     3     s  Lorg/reactivestreams/Subscription;
    MethodParameters:
      Name  Flags
      n     final
      s     final

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
         0: .line 141
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.cancel:(Ljava/util/concurrent/atomic/AtomicReference;)Z
            pop
         1: .line 142
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         2: .line 143
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableSubscribeOn$SubscribeOnSubscriber<TT;>;
}
Signature: <T:Ljava/lang/Object;>Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/Thread;>;Lio/reactivex/FlowableSubscriber<TT;>;Lorg/reactivestreams/Subscription;Ljava/lang/Runnable;
SourceFile: "FlowableSubscribeOn.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableSubscribeOn
InnerClasses:
  public abstract Worker = io.reactivex.Scheduler$Worker of io.reactivex.Scheduler
  final SubscribeOnSubscriber = io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber of io.reactivex.internal.operators.flowable.FlowableSubscribeOn
  final Request = io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber$Request of io.reactivex.internal.operators.flowable.FlowableSubscribeOn$SubscribeOnSubscriber