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

  final io.reactivex.functions.BiFunction<R, ? super T, R> reducer;
    descriptor: Lio/reactivex/functions/BiFunction;
    flags: (0x0010) ACC_FINAL
    Signature: Lio/reactivex/functions/BiFunction<TR;-TT;TR;>;

  R accumulator;
    descriptor: Ljava/lang/Object;
    flags: (0x0000) 
    Signature: TR;

  boolean done;
    descriptor: Z
    flags: (0x0000) 

  void <init>(org.reactivestreams.Subscriber<? super R>, R, io.reactivex.functions.BiFunction<R, ? super T, R>);
    descriptor: (Lorg/reactivestreams/Subscriber;Ljava/lang/Object;Lio/reactivex/functions/BiFunction;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
        start local 1 // org.reactivestreams.Subscriber subscriber
        start local 2 // java.lang.Object initialValue
        start local 3 // io.reactivex.functions.BiFunction reducer
         0: .line 98
            aload 0 /* this */
            aload 1 /* subscriber */
            invokespecial io.reactivex.internal.subscribers.DeferredScalarSubscriber.<init>:(Lorg/reactivestreams/Subscriber;)V
         1: .line 99
            aload 0 /* this */
            aload 2 /* initialValue */
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.accumulator:Ljava/lang/Object;
         2: .line 100
            aload 0 /* this */
            aload 3 /* reducer */
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.reducer:Lio/reactivex/functions/BiFunction;
         3: .line 101
            return
        end local 3 // io.reactivex.functions.BiFunction reducer
        end local 2 // java.lang.Object initialValue
        end local 1 // org.reactivestreams.Subscriber subscriber
        end local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    4     0          this  Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber<TT;TR;>;
            0    4     1    subscriber  Lorg/reactivestreams/Subscriber<-TR;>;
            0    4     2  initialValue  TR;
            0    4     3       reducer  Lio/reactivex/functions/BiFunction<TR;-TT;TR;>;
    Signature: (Lorg/reactivestreams/Subscriber<-TR;>;TR;Lio/reactivex/functions/BiFunction<TR;-TT;TR;>;)V
    MethodParameters:
              Name  Flags
      subscriber    
      initialValue  
      reducer       

  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.ParallelReduce$ParallelReduceSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 105
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.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 106
            aload 0 /* this */
            aload 1 /* s */
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.upstream:Lorg/reactivestreams/Subscription;
         2: .line 108
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 0 /* this */
            invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         3: .line 110
            aload 1 /* s */
            ldc 9223372036854775807
            invokeinterface org.reactivestreams.Subscription.request:(J)V
         4: .line 112
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber<TT;TR;>;
            0    5     1     s  Lorg/reactivestreams/Subscription;
    MethodParameters:
      Name  Flags
      s     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
        start local 1 // java.lang.Object t
         0: .line 116
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.done:Z
            ifne 9
         1: .line 120
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.reducer:Lio/reactivex/functions/BiFunction;
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.accumulator:Ljava/lang/Object;
            aload 1 /* t */
            invokeinterface io.reactivex.functions.BiFunction.apply:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            ldc "The reducer returned a null value"
            invokestatic io.reactivex.internal.functions.ObjectHelper.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            astore 2 /* v */
        start local 2 // java.lang.Object v
         2: .line 121
            goto 8
        end local 2 // java.lang.Object v
      StackMap locals:
      StackMap stack: java.lang.Throwable
         3: astore 3 /* ex */
        start local 3 // java.lang.Throwable ex
         4: .line 122
            aload 3 /* ex */
            invokestatic io.reactivex.exceptions.Exceptions.throwIfFatal:(Ljava/lang/Throwable;)V
         5: .line 123
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.cancel:()V
         6: .line 124
            aload 0 /* this */
            aload 3 /* ex */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.onError:(Ljava/lang/Throwable;)V
         7: .line 125
            return
        end local 3 // java.lang.Throwable ex
        start local 2 // java.lang.Object v
         8: .line 128
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            aload 2 /* v */
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.accumulator:Ljava/lang/Object;
        end local 2 // java.lang.Object v
         9: .line 130
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object t
        end local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber<TT;TR;>;
            0   10     1     t  TT;
            2    3     2     v  TR;
            8    9     2     v  TR;
            4    8     3    ex  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.Throwable
    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.parallel.ParallelReduce$ParallelReduceSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 134
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.done:Z
            ifeq 3
         1: .line 135
            aload 1 /* t */
            invokestatic io.reactivex.plugins.RxJavaPlugins.onError:(Ljava/lang/Throwable;)V
         2: .line 136
            return
         3: .line 138
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.done:Z
         4: .line 139
            aload 0 /* this */
            aconst_null
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.accumulator:Ljava/lang/Object;
         5: .line 140
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 1 /* t */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         6: .line 141
            return
        end local 1 // java.lang.Throwable t
        end local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber<TT;TR;>;
            0    7     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
         0: .line 145
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.done:Z
            ifne 5
         1: .line 146
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.done:Z
         2: .line 148
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.accumulator:Ljava/lang/Object;
            astore 1 /* a */
        start local 1 // java.lang.Object a
         3: .line 149
            aload 0 /* this */
            aconst_null
            putfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.accumulator:Ljava/lang/Object;
         4: .line 150
            aload 0 /* this */
            aload 1 /* a */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.complete:(Ljava/lang/Object;)V
        end local 1 // java.lang.Object a
         5: .line 152
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber<TT;TR;>;
            3    5     1     a  TR;

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
         0: .line 156
            aload 0 /* this */
            invokespecial io.reactivex.internal.subscribers.DeferredScalarSubscriber.cancel:()V
         1: .line 157
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber.upstream:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         2: .line 158
            return
        end local 0 // io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/parallel/ParallelReduce$ParallelReduceSubscriber<TT;TR;>;
}
Signature: <T:Ljava/lang/Object;R:Ljava/lang/Object;>Lio/reactivex/internal/subscribers/DeferredScalarSubscriber<TT;TR;>;
SourceFile: "ParallelReduce.java"
NestHost: io.reactivex.internal.operators.parallel.ParallelReduce
InnerClasses:
  final ParallelReduceSubscriber = io.reactivex.internal.operators.parallel.ParallelReduce$ParallelReduceSubscriber of io.reactivex.internal.operators.parallel.ParallelReduce