final class java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask<K, V> extends java.util.concurrent.ConcurrentHashMap$BulkTask<K, V, java.lang.Double>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask
super_class: java.util.concurrent.ConcurrentHashMap$BulkTask
{
final java.util.function.ToDoubleFunction<? super K> transformer;
descriptor: Ljava/util/function/ToDoubleFunction;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/function/ToDoubleFunction<-TK;>;
final java.util.function.DoubleBinaryOperator reducer;
descriptor: Ljava/util/function/DoubleBinaryOperator;
flags: (0x0010) ACC_FINAL
final double basis;
descriptor: D
flags: (0x0010) ACC_FINAL
double result;
descriptor: D
flags: (0x0000)
java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask<K, V> rights;
descriptor: Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
flags: (0x0000)
Signature: Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask<K, V> nextRight;
descriptor: Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
flags: (0x0000)
Signature: Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
void <init>(java.util.concurrent.ConcurrentHashMap$BulkTask<K, V, ?>, int, int, int, java.util.concurrent.ConcurrentHashMap$Node<K, V>[], java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask<K, V>, java.util.function.ToDoubleFunction<? super K>, double, java.util.function.DoubleBinaryOperator);
descriptor: (Ljava/util/concurrent/ConcurrentHashMap$BulkTask;III[Ljava/util/concurrent/ConcurrentHashMap$Node;Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;Ljava/util/function/ToDoubleFunction;DLjava/util/function/DoubleBinaryOperator;)V
flags: (0x0000)
Code:
stack=6, locals=11, args_size=10
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 10 0: aload 0
aload 1
iload 2
iload 3
iload 4
aload 5
invokespecial java.util.concurrent.ConcurrentHashMap$BulkTask.<init>:(Ljava/util/concurrent/ConcurrentHashMap$BulkTask;III[Ljava/util/concurrent/ConcurrentHashMap$Node;)V
aload 0
aload 6
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.nextRight:Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
1: aload 0
aload 7
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.transformer:Ljava/util/function/ToDoubleFunction;
2: aload 0
dload 8
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.basis:D
aload 0
aload 10
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.reducer:Ljava/util/function/DoubleBinaryOperator;
3: return
end local 10 end local 8 end local 7 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 4 0 this Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
0 4 1 p Ljava/util/concurrent/ConcurrentHashMap$BulkTask<TK;TV;*>;
0 4 2 b I
0 4 3 i I
0 4 4 f I
0 4 5 t [Ljava/util/concurrent/ConcurrentHashMap$Node;
0 4 6 nextRight Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
0 4 7 transformer Ljava/util/function/ToDoubleFunction<-TK;>;
0 4 8 basis D
0 4 10 reducer Ljava/util/function/DoubleBinaryOperator;
Signature: (Ljava/util/concurrent/ConcurrentHashMap$BulkTask<TK;TV;*>;III[Ljava/util/concurrent/ConcurrentHashMap$Node<TK;TV;>;Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;Ljava/util/function/ToDoubleFunction<-TK;>;DLjava/util/function/DoubleBinaryOperator;)V
MethodParameters:
Name Flags
p
b
i
f
t
nextRight
transformer
basis
reducer
public final java.lang.Double getRawResult();
descriptor: ()Ljava/lang/Double;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.result:D
invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
public final void compute();
descriptor: ()V
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=13, locals=8, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.transformer:Ljava/util/function/ToDoubleFunction;
dup
astore 1
start local 1 1: ifnull 33
2: aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.reducer:Ljava/util/function/DoubleBinaryOperator;
dup
astore 2
start local 2 3: ifnull 33
4: aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.basis:D
dstore 3
start local 3 5: aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.baseIndex:I
istore 5
start local 5 6: goto 13
start local 6 start local 7 7: StackMap locals: java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask java.util.function.ToDoubleFunction java.util.function.DoubleBinaryOperator double int int int
StackMap stack:
aload 0
iconst_1
invokevirtual java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.addToPendingCount:(I)V
8: aload 0
new java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask
dup
9: aload 0
aload 0
dup
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.batch:I
iconst_1
iushr
dup_x1
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.batch:I
aload 0
iload 7
dup_x1
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.baseLimit:I
iload 6
aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.tab:[Ljava/util/concurrent/ConcurrentHashMap$Node;
10: aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.rights:Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
aload 1
dload 3
aload 2
invokespecial java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.<init>:(Ljava/util/concurrent/ConcurrentHashMap$BulkTask;III[Ljava/util/concurrent/ConcurrentHashMap$Node;Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;Ljava/util/function/ToDoubleFunction;DLjava/util/function/DoubleBinaryOperator;)V
11: dup_x1
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.rights:Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
12: invokevirtual java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.fork:()Ljava/util/concurrent/ForkJoinTask;
pop
end local 7 end local 6 13: StackMap locals:
StackMap stack:
aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.batch:I
ifle 20
14: aload 0
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.baseLimit:I
dup
istore 6
start local 6 15: iload 5
iadd
iconst_1
iushr
dup
istore 7
start local 7 16: iload 5
17: if_icmpgt 7
end local 7 end local 6 end local 5 18: goto 20
start local 5 19: StackMap locals: java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask java.util.function.ToDoubleFunction java.util.function.DoubleBinaryOperator double java.util.concurrent.ConcurrentHashMap$Node
StackMap stack:
aload 2
dload 3
aload 1
aload 5
getfield java.util.concurrent.ConcurrentHashMap$Node.key:Ljava/lang/Object;
invokeinterface java.util.function.ToDoubleFunction.applyAsDouble:(Ljava/lang/Object;)D
invokeinterface java.util.function.DoubleBinaryOperator.applyAsDouble:(DD)D
dstore 3
end local 5 20: StackMap locals:
StackMap stack:
aload 0
invokevirtual java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.advance:()Ljava/util/concurrent/ConcurrentHashMap$Node;
dup
astore 5
start local 5 21: ifnonnull 19
end local 5 22: aload 0
dload 3
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.result:D
23: aload 0
invokevirtual java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.firstComplete:()Ljava/util/concurrent/CountedCompleter;
astore 5
start local 5 24: goto 32
25: StackMap locals: java.util.concurrent.CountedCompleter
StackMap stack:
aload 5
checkcast java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask
astore 6
start local 6 26: aload 6
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.rights:Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
astore 7
start local 7 27: goto 30
28: StackMap locals: java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask
StackMap stack:
aload 6
aload 2
aload 6
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.result:D
aload 7
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.result:D
invokeinterface java.util.function.DoubleBinaryOperator.applyAsDouble:(DD)D
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.result:D
29: aload 6
aload 7
getfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.nextRight:Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
dup_x1
putfield java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.rights:Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask;
astore 7
30: StackMap locals:
StackMap stack:
aload 7
ifnonnull 28
end local 7 end local 6 31: aload 5
invokevirtual java.util.concurrent.CountedCompleter.nextComplete:()Ljava/util/concurrent/CountedCompleter;
astore 5
StackMap locals:
StackMap stack:
32: aload 5
ifnonnull 25
end local 5 end local 3 end local 2 33: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 34 0 this Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
1 34 1 transformer Ljava/util/function/ToDoubleFunction<-TK;>;
3 33 2 reducer Ljava/util/function/DoubleBinaryOperator;
5 33 3 r D
6 18 5 i I
7 13 6 f I
15 18 6 f I
7 13 7 h I
16 18 7 h I
19 20 5 p Ljava/util/concurrent/ConcurrentHashMap$Node<TK;TV;>;
21 22 5 p Ljava/util/concurrent/ConcurrentHashMap$Node<TK;TV;>;
24 33 5 c Ljava/util/concurrent/CountedCompleter<*>;
26 31 6 t Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
27 31 7 s Ljava/util/concurrent/ConcurrentHashMap$MapReduceKeysToDoubleTask<TK;TV;>;
public java.lang.Object getRawResult();
descriptor: ()Ljava/lang/Object;
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokevirtual java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask.getRawResult:()Ljava/lang/Double;
areturn
LocalVariableTable:
Start End Slot Name Signature
}
Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>Ljava/util/concurrent/ConcurrentHashMap$BulkTask<TK;TV;Ljava/lang/Double;>;
SourceFile: "ConcurrentHashMap.java"
NestHost: java.util.concurrent.ConcurrentHashMap
InnerClasses:
abstract BulkTask = java.util.concurrent.ConcurrentHashMap$BulkTask of java.util.concurrent.ConcurrentHashMap
final MapReduceKeysToDoubleTask = java.util.concurrent.ConcurrentHashMap$MapReduceKeysToDoubleTask of java.util.concurrent.ConcurrentHashMap
Node = java.util.concurrent.ConcurrentHashMap$Node of java.util.concurrent.ConcurrentHashMap