final class java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator implements java.util.Spliterator$OfInt
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator
super_class: java.lang.Object
{
long index;
descriptor: J
flags: (0x0000)
final long fence;
descriptor: J
flags: (0x0010) ACC_FINAL
final int origin;
descriptor: I
flags: (0x0010) ACC_FINAL
final int bound;
descriptor: I
flags: (0x0010) ACC_FINAL
void <init>(long, long, int, int);
descriptor: (JJII)V
flags: (0x0000)
Code:
stack=3, locals=7, args_size=5
start local 0 start local 1 start local 3 start local 5 start local 6 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
lload 1
putfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.index:J
aload 0
lload 3
putfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.fence:J
2: aload 0
iload 5
putfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.origin:I
aload 0
iload 6
putfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.bound:I
3: return
end local 6 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$RandomIntsSpliterator;
0 4 1 index J
0 4 3 fence J
0 4 5 origin I
0 4 6 bound I
MethodParameters:
Name Flags
index
fence
origin
bound
public java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator trySplit();
descriptor: ()Ljava/util/concurrent/ThreadLocalRandom$RandomIntsSpliterator;
flags: (0x0001) ACC_PUBLIC
Code:
stack=9, locals=5, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.index:J
lstore 1
start local 1 1: lload 1
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.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$RandomIntsSpliterator
dup
lload 1
aload 0
lload 3
dup2_x1
putfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.index:J
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.origin:I
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.bound:I
invokespecial java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.<init>:(JJII)V
4: StackMap locals:
StackMap stack: java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator
areturn
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomIntsSpliterator;
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$RandomIntsSpliterator.fence:J
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.index:J
lsub
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/concurrent/ThreadLocalRandom$RandomIntsSpliterator;
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$RandomIntsSpliterator;
public boolean tryAdvance(java.util.function.IntConsumer);
descriptor: (Ljava/util/function/IntConsumer;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, 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$RandomIntsSpliterator.index:J
lstore 2
start local 2 2: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.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$RandomIntsSpliterator.origin:I
aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.bound:I
invokevirtual java.util.concurrent.ThreadLocalRandom.internalNextInt:(II)I
invokeinterface java.util.function.IntConsumer.accept:(I)V
5: aload 0
lload 2
lconst_1
ladd
putfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.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$RandomIntsSpliterator;
0 8 1 consumer Ljava/util/function/IntConsumer;
2 8 2 i J
3 8 4 f J
MethodParameters:
Name Flags
consumer
public void forEachRemaining(java.util.function.IntConsumer);
descriptor: (Ljava/util/function/IntConsumer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=9, 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$RandomIntsSpliterator.index:J
lstore 2
start local 2 2: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.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$RandomIntsSpliterator.index:J
5: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.origin:I
istore 6
start local 6 6: aload 0
getfield java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.bound:I
istore 7
start local 7 7: invokestatic java.util.concurrent.ThreadLocalRandom.current:()Ljava/util/concurrent/ThreadLocalRandom;
astore 8
start local 8 8: StackMap locals: java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator java.util.function.IntConsumer long long int int java.util.concurrent.ThreadLocalRandom
StackMap stack:
aload 1
aload 8
iload 6
iload 7
invokevirtual java.util.concurrent.ThreadLocalRandom.internalNextInt:(II)I
invokeinterface java.util.function.IntConsumer.accept:(I)V
9: lload 2
lconst_1
ladd
dup2
lstore 2
lload 4
10: lcmp
iflt 8
end local 8 end local 7 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$RandomIntsSpliterator;
0 12 1 consumer Ljava/util/function/IntConsumer;
2 12 2 i J
3 12 4 f J
6 11 6 o I
7 11 7 b I
8 11 8 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.IntConsumer
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.tryAdvance:(Ljava/util/function/IntConsumer;)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.IntConsumer
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.forEachRemaining:(Ljava/util/function/IntConsumer;)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$RandomIntsSpliterator.trySplit:()Ljava/util/concurrent/ThreadLocalRandom$RandomIntsSpliterator;
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$RandomIntsSpliterator.trySplit:()Ljava/util/concurrent/ThreadLocalRandom$RandomIntsSpliterator;
areturn
LocalVariableTable:
Start End Slot Name Signature
public java.util.Spliterator$OfInt trySplit();
descriptor: ()Ljava/util/Spliterator$OfInt;
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokevirtual java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator.trySplit:()Ljava/util/concurrent/ThreadLocalRandom$RandomIntsSpliterator;
areturn
LocalVariableTable:
Start End Slot Name Signature
}
SourceFile: "ThreadLocalRandom.java"
NestHost: java.util.concurrent.ThreadLocalRandom
InnerClasses:
public abstract OfInt = java.util.Spliterator$OfInt of java.util.Spliterator
public abstract OfPrimitive = java.util.Spliterator$OfPrimitive of java.util.Spliterator
private final RandomIntsSpliterator = java.util.concurrent.ThreadLocalRandom$RandomIntsSpliterator of java.util.concurrent.ThreadLocalRandom