final class java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator implements java.util.Spliterator$OfDouble
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator
super_class: java.lang.Object
{
long index;
descriptor: J
flags: (0x0000)
final long fence;
descriptor: J
flags: (0x0010) ACC_FINAL
final double origin;
descriptor: D
flags: (0x0010) ACC_FINAL
final double bound;
descriptor: D
flags: (0x0010) ACC_FINAL
void <init>(long, long, double, double);
descriptor: (JJDD)V
flags: (0x0000)
Code:
stack=3, locals=9, args_size=5
start local 0 start local 1 start local 3 start local 5 start local 7 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
lload 1
putfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
aload 0
lload 3
putfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.fence:J
2: aload 0
dload 5
putfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.origin:D
aload 0
dload 7
putfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.bound:D
3: return
end local 7 end local 5 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
0 4 1 index J
0 4 3 fence J
0 4 5 origin D
0 4 7 bound D
MethodParameters:
Name Flags
index
fence
origin
bound
public java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator trySplit();
descriptor: ()Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
flags: (0x0001) ACC_PUBLIC
Code:
stack=10, locals=5, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
lstore 1
start local 1 1: lload 1
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.fence:J
ladd
iconst_1
lushr
lstore 3
start local 3 2: lload 3
lload 1
lcmp
ifgt 3
aconst_null
goto 4
3: StackMap locals: long long
StackMap stack:
new java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator
dup
lload 1
aload 0
lload 3
dup2_x1
putfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.origin:D
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.bound:D
invokespecial java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.<init>:(JJDD)V
4: StackMap locals:
StackMap stack: java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator
areturn
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
1 5 1 i J
2 5 3 m J
public long estimateSize();
descriptor: ()J
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.fence:J
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
lsub
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
public int characteristics();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: sipush 17728
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
public boolean tryAdvance(java.util.function.DoubleConsumer);
descriptor: (Ljava/util/function/DoubleConsumer;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=6, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 1
new java.lang.NullPointerException
dup
invokespecial java.lang.NullPointerException.<init>:()V
athrow
1: StackMap locals:
StackMap stack:
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
lstore 2
start local 2 2: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.fence:J
lstore 4
start local 4 3: lload 2
lload 4
lcmp
ifge 7
4: aload 1
invokestatic java.util.concurrent.ThreadLocalRandom.current:()Ljava/util/concurrent/ThreadLocalRandom;
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.origin:D
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.bound:D
invokevirtual java.util.concurrent.ThreadLocalRandom.internalNextDouble:(DD)D
invokeinterface java.util.function.DoubleConsumer.accept:(D)V
5: aload 0
lload 2
lconst_1
ladd
putfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
6: iconst_1
ireturn
7: StackMap locals: long long
StackMap stack:
iconst_0
ireturn
end local 4 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
0 8 1 consumer Ljava/util/function/DoubleConsumer;
2 8 2 i J
3 8 4 f J
MethodParameters:
Name Flags
consumer
public void forEachRemaining(java.util.function.DoubleConsumer);
descriptor: (Ljava/util/function/DoubleConsumer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=11, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 1
new java.lang.NullPointerException
dup
invokespecial java.lang.NullPointerException.<init>:()V
athrow
1: StackMap locals:
StackMap stack:
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
lstore 2
start local 2 2: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.fence:J
lstore 4
start local 4 3: lload 2
lload 4
lcmp
ifge 11
4: aload 0
lload 4
putfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.index:J
5: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.origin:D
dstore 6
start local 6 6: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.bound:D
dstore 8
start local 8 7: invokestatic java.util.concurrent.ThreadLocalRandom.current:()Ljava/util/concurrent/ThreadLocalRandom;
astore 10
start local 10 8: StackMap locals: java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator java.util.function.DoubleConsumer long long double double java.util.concurrent.ThreadLocalRandom
StackMap stack:
aload 1
aload 10
dload 6
dload 8
invokevirtual java.util.concurrent.ThreadLocalRandom.internalNextDouble:(DD)D
invokeinterface java.util.function.DoubleConsumer.accept:(D)V
9: lload 2
lconst_1
ladd
dup2
lstore 2
lload 4
10: lcmp
iflt 8
end local 10 end local 8 end local 6 11: StackMap locals:
StackMap stack:
return
end local 4 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
0 12 1 consumer Ljava/util/function/DoubleConsumer;
2 12 2 i J
3 12 4 f J
6 11 6 o D
7 11 8 b D
8 11 10 rng Ljava/util/concurrent/ThreadLocalRandom;
MethodParameters:
Name Flags
consumer
public boolean tryAdvance(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
0: aload 0
aload 1
checkcast java.util.function.DoubleConsumer
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.tryAdvance:(Ljava/util/function/DoubleConsumer;)Z
ireturn
LocalVariableTable:
Start End Slot Name Signature
public void forEachRemaining(java.lang.Object);
descriptor: (Ljava/lang/Object;)V
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
0: aload 0
aload 1
checkcast java.util.function.DoubleConsumer
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.forEachRemaining:(Ljava/util/function/DoubleConsumer;)V
return
LocalVariableTable:
Start End Slot Name Signature
public java.util.Spliterator trySplit();
descriptor: ()Ljava/util/Spliterator;
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.trySplit:()Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
areturn
LocalVariableTable:
Start End Slot Name Signature
public java.util.Spliterator$OfPrimitive trySplit();
descriptor: ()Ljava/util/Spliterator$OfPrimitive;
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.trySplit:()Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
areturn
LocalVariableTable:
Start End Slot Name Signature
public java.util.Spliterator$OfDouble trySplit();
descriptor: ()Ljava/util/Spliterator$OfDouble;
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator.trySplit:()Ljava/util/concurrent/ThreadLocalRandom$RandomDoublesSpliterator;
areturn
LocalVariableTable:
Start End Slot Name Signature
}
SourceFile: "ThreadLocalRandom.java"
NestHost: java.util.concurrent.ThreadLocalRandom
InnerClasses:
public abstract OfDouble = java.util.Spliterator$OfDouble of java.util.Spliterator
public abstract OfPrimitive = java.util.Spliterator$OfPrimitive of java.util.Spliterator
private final RandomDoublesSpliterator = java.util.concurrent.ThreadLocalRandom$RandomDoublesSpliterator of java.util.concurrent.ThreadLocalRandom