final class reactor.core.publisher.FluxGroupBy<T, K, V> extends reactor.core.publisher.InternalFluxOperator<T, reactor.core.publisher.GroupedFlux<K, V>> implements reactor.core.Fuseable
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: reactor.core.publisher.FluxGroupBy
super_class: reactor.core.publisher.InternalFluxOperator
{
final java.util.function.Function<? super T, ? extends K> keySelector;
descriptor: Ljava/util/function/Function;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Function<-TT;+TK;>;
final java.util.function.Function<? super T, ? extends V> valueSelector;
descriptor: Ljava/util/function/Function;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Function<-TT;+TV;>;
final java.util.function.Supplier<? extends java.util.Queue<V>> groupQueueSupplier;
descriptor: Ljava/util/function/Supplier;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Supplier<+Ljava/util/Queue<TV;>;>;
final java.util.function.Supplier<? extends java.util.Queue<reactor.core.publisher.GroupedFlux<K, V>>> mainQueueSupplier;
descriptor: Ljava/util/function/Supplier;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/Supplier<+Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;>;
final int prefetch;
descriptor: I
flags: (0x0010) ACC_FINAL
void <init>(reactor.core.publisher.Flux<? extends T>, java.util.function.Function<? super T, ? extends K>, java.util.function.Function<? super T, ? extends V>, java.util.function.Supplier<? extends java.util.Queue<reactor.core.publisher.GroupedFlux<K, V>>>, java.util.function.Supplier<? extends java.util.Queue<V>>, );
descriptor: (Lreactor/core/publisher/Flux;Ljava/util/function/Function;Ljava/util/function/Function;Ljava/util/function/Supplier;Ljava/util/function/Supplier;I)V
flags: (0x0000)
Code:
stack=5, locals=7, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 0
aload 1
invokespecial reactor.core.publisher.InternalFluxOperator.<init>:(Lreactor/core/publisher/Flux;)V
1: iload 6
ifgt 3
2: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
ldc "prefetch > 0 required but it was "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 6
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: reactor.core.publisher.FluxGroupBy reactor.core.publisher.Flux java.util.function.Function java.util.function.Function java.util.function.Supplier java.util.function.Supplier int
StackMap stack:
aload 0
aload 2
ldc "keySelector"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.function.Function
putfield reactor.core.publisher.FluxGroupBy.keySelector:Ljava/util/function/Function;
4: aload 0
aload 3
ldc "valueSelector"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.function.Function
putfield reactor.core.publisher.FluxGroupBy.valueSelector:Ljava/util/function/Function;
5: aload 0
6: aload 4
ldc "mainQueueSupplier"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.function.Supplier
7: putfield reactor.core.publisher.FluxGroupBy.mainQueueSupplier:Ljava/util/function/Supplier;
8: aload 0
9: aload 5
ldc "groupQueueSupplier"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.function.Supplier
10: putfield reactor.core.publisher.FluxGroupBy.groupQueueSupplier:Ljava/util/function/Supplier;
11: aload 0
iload 6
putfield reactor.core.publisher.FluxGroupBy.prefetch:I
12: return
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lreactor/core/publisher/FluxGroupBy<TT;TK;TV;>;
0 13 1 source Lreactor/core/publisher/Flux<+TT;>;
0 13 2 keySelector Ljava/util/function/Function<-TT;+TK;>;
0 13 3 valueSelector Ljava/util/function/Function<-TT;+TV;>;
0 13 4 mainQueueSupplier Ljava/util/function/Supplier<+Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;>;
0 13 5 groupQueueSupplier Ljava/util/function/Supplier<+Ljava/util/Queue<TV;>;>;
0 13 6 prefetch I
Signature: (Lreactor/core/publisher/Flux<+TT;>;Ljava/util/function/Function<-TT;+TK;>;Ljava/util/function/Function<-TT;+TV;>;Ljava/util/function/Supplier<+Ljava/util/Queue<Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;>;Ljava/util/function/Supplier<+Ljava/util/Queue<TV;>;>;I)V
MethodParameters:
Name Flags
source
keySelector
valueSelector
mainQueueSupplier
groupQueueSupplier
prefetch
public reactor.core.CoreSubscriber<? super T> subscribeOrReturn(reactor.core.CoreSubscriber<? super reactor.core.publisher.GroupedFlux<K, V>>);
descriptor: (Lreactor/core/CoreSubscriber;)Lreactor/core/CoreSubscriber;
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=2, args_size=2
start local 0 start local 1 0: new reactor.core.publisher.FluxGroupBy$GroupByMain
dup
aload 1
1: aload 0
getfield reactor.core.publisher.FluxGroupBy.mainQueueSupplier:Ljava/util/function/Supplier;
invokeinterface java.util.function.Supplier.get:()Ljava/lang/Object;
checkcast java.util.Queue
2: aload 0
getfield reactor.core.publisher.FluxGroupBy.groupQueueSupplier:Ljava/util/function/Supplier;
3: aload 0
getfield reactor.core.publisher.FluxGroupBy.prefetch:I
4: aload 0
getfield reactor.core.publisher.FluxGroupBy.keySelector:Ljava/util/function/Function;
aload 0
getfield reactor.core.publisher.FluxGroupBy.valueSelector:Ljava/util/function/Function;
5: invokespecial reactor.core.publisher.FluxGroupBy$GroupByMain.<init>:(Lreactor/core/CoreSubscriber;Ljava/util/Queue;Ljava/util/function/Supplier;ILjava/util/function/Function;Ljava/util/function/Function;)V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lreactor/core/publisher/FluxGroupBy<TT;TK;TV;>;
0 6 1 actual Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;
Signature: (Lreactor/core/CoreSubscriber<-Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;)Lreactor/core/CoreSubscriber<-TT;>;
MethodParameters:
Name Flags
actual
public int getPrefetch();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.publisher.FluxGroupBy.prefetch:I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lreactor/core/publisher/FluxGroupBy<TT;TK;TV;>;
public java.lang.Object scanUnsafe(reactor.core.Scannable$Attr);
descriptor: (Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
if_acmpne 1
getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
areturn
1: StackMap locals:
StackMap stack:
aload 0
aload 1
invokespecial reactor.core.publisher.InternalFluxOperator.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lreactor/core/publisher/FluxGroupBy<TT;TK;TV;>;
0 2 1 key Lreactor/core/Scannable$Attr;
MethodParameters:
Name Flags
key
}
Signature: <T:Ljava/lang/Object;K:Ljava/lang/Object;V:Ljava/lang/Object;>Lreactor/core/publisher/InternalFluxOperator<TT;Lreactor/core/publisher/GroupedFlux<TK;TV;>;>;Lreactor/core/Fuseable;
SourceFile: "FluxGroupBy.java"
NestMembers:
reactor.core.publisher.FluxGroupBy$GroupByMain reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux
InnerClasses:
public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
final GroupByMain = reactor.core.publisher.FluxGroupBy$GroupByMain of reactor.core.publisher.FluxGroupBy
final UnicastGroupedFlux = reactor.core.publisher.FluxGroupBy$UnicastGroupedFlux of reactor.core.publisher.FluxGroupBy