final class org.h2.mvstore.MVStore$ChunkIdsCollector
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: org.h2.mvstore.MVStore$ChunkIdsCollector
super_class: java.lang.Object
{
private final java.util.concurrent.ConcurrentHashMap<java.lang.Integer, java.lang.Integer> referencedChunks;
descriptor: Ljava/util/concurrent/ConcurrentHashMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/concurrent/ConcurrentHashMap<Ljava/lang/Integer;Ljava/lang/Integer;>;
private final org.h2.mvstore.MVStore$ChunkIdsCollector parent;
descriptor: Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private int mapId;
descriptor: I
flags: (0x0002) ACC_PRIVATE
final org.h2.mvstore.MVStore this$0;
descriptor: Lorg/h2/mvstore/MVStore;
flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC
void <init>(org.h2.mvstore.MVStore, int);
descriptor: (Lorg/h2/mvstore/MVStore;I)V
flags: (0x0000)
Code:
stack=3, locals=3, args_size=3
start local 0 start local 2 0: aload 0
aload 1
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.concurrent.ConcurrentHashMap
dup
invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.referencedChunks:Ljava/util/concurrent/ConcurrentHashMap;
2: aload 0
aconst_null
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.parent:Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
3: aload 0
iload 2
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.mapId:I
4: return
end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
0 5 2 mapId I
MethodParameters:
Name Flags
this$0 final
mapId
private void <init>(org.h2.mvstore.MVStore, org.h2.mvstore.MVStore$ChunkIdsCollector);
descriptor: (Lorg/h2/mvstore/MVStore;Lorg/h2/mvstore/MVStore$ChunkIdsCollector;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=3
start local 0 start local 2 0: aload 0
aload 1
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.concurrent.ConcurrentHashMap
dup
invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.referencedChunks:Ljava/util/concurrent/ConcurrentHashMap;
2: aload 0
aload 2
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.parent:Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
3: aload 0
aload 2
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.mapId:I
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.mapId:I
4: return
end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
0 5 2 parent Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
MethodParameters:
Name Flags
this$0 final
parent
public int getMapId();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.mapId:I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
public void setMapId(int);
descriptor: (I)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield org.h2.mvstore.MVStore$ChunkIdsCollector.mapId:I
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
0 2 1 mapId I
MethodParameters:
Name Flags
mapId
public java.util.Set<java.lang.Integer> getReferenced();
descriptor: ()Ljava/util/Set;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: new java.util.HashSet
dup
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.referencedChunks:Ljava/util/concurrent/ConcurrentHashMap;
invokevirtual java.util.concurrent.ConcurrentHashMap.keySet:()Ljava/util/concurrent/ConcurrentHashMap$KeySetView;
invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
Signature: ()Ljava/util/Set<Ljava/lang/Integer;>;
public void visit(org.h2.mvstore.Page, java.util.concurrent.ThreadPoolExecutor, java.util.concurrent.atomic.AtomicInteger);
descriptor: (Lorg/h2/mvstore/Page;Ljava/util/concurrent/ThreadPoolExecutor;Ljava/util/concurrent/atomic/AtomicInteger;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=10, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 1
invokevirtual org.h2.mvstore.Page.getPos:()J
lstore 4
start local 4 1: lload 4
invokestatic org.h2.mvstore.DataUtils.isPageSaved:(J)Z
ifeq 3
2: aload 0
lload 4
invokestatic org.h2.mvstore.DataUtils.getPageChunkId:(J)I
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.registerChunk:(I)V
3: StackMap locals: long
StackMap stack:
aload 1
getfield org.h2.mvstore.Page.map:Lorg/h2/mvstore/MVMap;
aload 1
invokevirtual org.h2.mvstore.MVMap.getChildPageCount:(Lorg/h2/mvstore/Page;)I
istore 6
start local 6 4: iload 6
ifne 6
5: return
6: StackMap locals: int
StackMap stack:
lload 4
invokestatic org.h2.mvstore.DataUtils.isPageSaved:(J)Z
ifeq 8
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
getfield org.h2.mvstore.MVStore.cacheChunkRef:Lorg/h2/mvstore/cache/CacheLongKeyLIRS;
ifnull 8
7: new org.h2.mvstore.MVStore$ChunkIdsCollector
dup
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
aload 0
invokespecial org.h2.mvstore.MVStore$ChunkIdsCollector.<init>:(Lorg/h2/mvstore/MVStore;Lorg/h2/mvstore/MVStore$ChunkIdsCollector;)V
goto 9
StackMap locals:
StackMap stack:
8: aload 0
9: StackMap locals:
StackMap stack: org.h2.mvstore.MVStore$ChunkIdsCollector
astore 7
start local 7 10: iconst_0
istore 8
start local 8 11: goto 18
12: StackMap locals: org.h2.mvstore.MVStore$ChunkIdsCollector int
StackMap stack:
aload 1
iload 8
invokevirtual org.h2.mvstore.Page.getChildPageIfLoaded:(I)Lorg/h2/mvstore/Page;
astore 9
start local 9 13: aload 9
ifnull 16
14: aload 7
aload 9
aload 2
aload 3
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.visit:(Lorg/h2/mvstore/Page;Ljava/util/concurrent/ThreadPoolExecutor;Ljava/util/concurrent/atomic/AtomicInteger;)V
15: goto 17
16: StackMap locals: org.h2.mvstore.Page
StackMap stack:
aload 7
aload 1
iload 8
invokevirtual org.h2.mvstore.Page.getChildPagePos:(I)J
aload 2
aload 3
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.visit:(JLjava/util/concurrent/ThreadPoolExecutor;Ljava/util/concurrent/atomic/AtomicInteger;)V
end local 9 17: StackMap locals:
StackMap stack:
iinc 8 1
StackMap locals:
StackMap stack:
18: iload 8
iload 6
if_icmplt 12
end local 8 19: aload 0
lload 4
aload 7
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.cacheCollectedChunkIds:(JLorg/h2/mvstore/MVStore$ChunkIdsCollector;)V
20: return
end local 7 end local 6 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
0 21 1 page Lorg/h2/mvstore/Page;
0 21 2 executorService Ljava/util/concurrent/ThreadPoolExecutor;
0 21 3 executingThreadCounter Ljava/util/concurrent/atomic/AtomicInteger;
1 21 4 pos J
4 21 6 count I
10 21 7 childCollector Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
11 19 8 i I
13 17 9 childPage Lorg/h2/mvstore/Page;
MethodParameters:
Name Flags
page
executorService
executingThreadCounter
public void visit(long, java.util.concurrent.ThreadPoolExecutor, java.util.concurrent.atomic.AtomicInteger);
descriptor: (JLjava/util/concurrent/ThreadPoolExecutor;Ljava/util/concurrent/atomic/AtomicInteger;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=10, args_size=4
start local 0 start local 1 start local 3 start local 4 0: lload 1
invokestatic org.h2.mvstore.DataUtils.isPageSaved:(J)Z
ifne 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
lload 1
invokestatic org.h2.mvstore.DataUtils.getPageChunkId:(J)I
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.registerChunk:(I)V
3: lload 1
invokestatic org.h2.mvstore.DataUtils.getPageType:(J)I
ifne 5
4: return
5: StackMap locals:
StackMap stack:
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
getfield org.h2.mvstore.MVStore.cacheChunkRef:Lorg/h2/mvstore/cache/CacheLongKeyLIRS;
ifnull 13
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
getfield org.h2.mvstore.MVStore.cacheChunkRef:Lorg/h2/mvstore/cache/CacheLongKeyLIRS;
lload 1
invokevirtual org.h2.mvstore.cache.CacheLongKeyLIRS.get:(J)Ljava/lang/Object;
checkcast int[]
dup
astore 5
start local 5 6: ifnull 13
7: aload 5
dup
astore 9
arraylength
istore 8
iconst_0
istore 7
goto 11
StackMap locals: org.h2.mvstore.MVStore$ChunkIdsCollector long java.util.concurrent.ThreadPoolExecutor java.util.concurrent.atomic.AtomicInteger int[] top int int int[]
StackMap stack:
8: aload 9
iload 7
iaload
istore 6
start local 6 9: aload 0
iload 6
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.registerChunk:(I)V
end local 6 10: iinc 7 1
StackMap locals:
StackMap stack:
11: iload 7
iload 8
if_icmplt 8
12: goto 23
end local 5 13: StackMap locals: org.h2.mvstore.MVStore$ChunkIdsCollector long java.util.concurrent.ThreadPoolExecutor java.util.concurrent.atomic.AtomicInteger
StackMap stack:
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
getfield org.h2.mvstore.MVStore.cacheChunkRef:Lorg/h2/mvstore/cache/CacheLongKeyLIRS;
ifnull 14
new org.h2.mvstore.MVStore$ChunkIdsCollector
dup
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
aload 0
invokespecial org.h2.mvstore.MVStore$ChunkIdsCollector.<init>:(Lorg/h2/mvstore/MVStore;Lorg/h2/mvstore/MVStore$ChunkIdsCollector;)V
goto 15
StackMap locals:
StackMap stack:
14: aload 0
StackMap locals:
StackMap stack: org.h2.mvstore.MVStore$ChunkIdsCollector
15: astore 6
start local 6 16: aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
getfield org.h2.mvstore.MVStore.cache:Lorg/h2/mvstore/cache/CacheLongKeyLIRS;
ifnull 20
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
getfield org.h2.mvstore.MVStore.cache:Lorg/h2/mvstore/cache/CacheLongKeyLIRS;
lload 1
invokevirtual org.h2.mvstore.cache.CacheLongKeyLIRS.get:(J)Ljava/lang/Object;
checkcast org.h2.mvstore.Page
dup
astore 7
start local 7 17: ifnull 20
18: aload 6
aload 7
aload 3
aload 4
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.visit:(Lorg/h2/mvstore/Page;Ljava/util/concurrent/ThreadPoolExecutor;Ljava/util/concurrent/atomic/AtomicInteger;)V
19: goto 22
end local 7 20: StackMap locals: org.h2.mvstore.MVStore$ChunkIdsCollector long java.util.concurrent.ThreadPoolExecutor java.util.concurrent.atomic.AtomicInteger top org.h2.mvstore.MVStore$ChunkIdsCollector
StackMap stack:
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
lload 1
aload 0
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.getMapId:()I
invokevirtual org.h2.mvstore.MVStore.readBufferForPage:(JI)Ljava/nio/ByteBuffer;
astore 8
start local 8 21: aload 8
lload 1
aload 6
aload 3
aload 4
invokestatic org.h2.mvstore.Page.readChildrenPositions:(Ljava/nio/ByteBuffer;JLorg/h2/mvstore/MVStore$ChunkIdsCollector;Ljava/util/concurrent/ThreadPoolExecutor;Ljava/util/concurrent/atomic/AtomicInteger;)V
end local 8 22: StackMap locals:
StackMap stack:
aload 0
lload 1
aload 6
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.cacheCollectedChunkIds:(JLorg/h2/mvstore/MVStore$ChunkIdsCollector;)V
end local 6 23: StackMap locals: org.h2.mvstore.MVStore$ChunkIdsCollector long java.util.concurrent.ThreadPoolExecutor java.util.concurrent.atomic.AtomicInteger
StackMap stack:
return
end local 4 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
0 24 1 pos J
0 24 3 executorService Ljava/util/concurrent/ThreadPoolExecutor;
0 24 4 executingThreadCounter Ljava/util/concurrent/atomic/AtomicInteger;
6 13 5 chunkIds [I
9 10 6 chunkId I
16 23 6 childCollector Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
17 20 7 page Lorg/h2/mvstore/Page;
21 22 8 buff Ljava/nio/ByteBuffer;
MethodParameters:
Name Flags
pos
executorService
executingThreadCounter
void registerChunk(int);
descriptor: (I)V
flags: (0x0000)
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.referencedChunks:Ljava/util/concurrent/ConcurrentHashMap;
iload 1
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
iconst_1
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
ifnonnull 2
aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.parent:Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
ifnull 2
1: aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.parent:Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
iload 1
invokevirtual org.h2.mvstore.MVStore$ChunkIdsCollector.registerChunk:(I)V
2: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
0 3 1 chunkId I
MethodParameters:
Name Flags
chunkId
private void cacheCollectedChunkIds(long, org.h2.mvstore.MVStore$ChunkIdsCollector);
descriptor: (JLorg/h2/mvstore/MVStore$ChunkIdsCollector;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=7, locals=8, args_size=3
start local 0 start local 1 start local 3 0: aload 3
aload 0
if_acmpeq 8
1: aload 3
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.referencedChunks:Ljava/util/concurrent/ConcurrentHashMap;
invokevirtual java.util.concurrent.ConcurrentHashMap.size:()I
newarray 10
astore 4
start local 4 2: iconst_0
istore 5
start local 5 3: aload 3
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.referencedChunks:Ljava/util/concurrent/ConcurrentHashMap;
invokevirtual java.util.concurrent.ConcurrentHashMap.keySet:()Ljava/util/concurrent/ConcurrentHashMap$KeySetView;
invokevirtual java.util.concurrent.ConcurrentHashMap$KeySetView.iterator:()Ljava/util/Iterator;
astore 7
goto 6
StackMap locals: org.h2.mvstore.MVStore$ChunkIdsCollector long org.h2.mvstore.MVStore$ChunkIdsCollector int[] int top java.util.Iterator
StackMap stack:
4: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Integer
astore 6
start local 6 5: aload 4
iload 5
iinc 5 1
aload 6
invokevirtual java.lang.Integer.intValue:()I
iastore
end local 6 6: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
7: aload 0
getfield org.h2.mvstore.MVStore$ChunkIdsCollector.this$0:Lorg/h2/mvstore/MVStore;
getfield org.h2.mvstore.MVStore.cacheChunkRef:Lorg/h2/mvstore/cache/CacheLongKeyLIRS;
lload 1
aload 4
bipush 24
iconst_4
aload 4
arraylength
imul
iadd
invokevirtual org.h2.mvstore.cache.CacheLongKeyLIRS.put:(JLjava/lang/Object;I)Ljava/lang/Object;
pop
end local 5 end local 4 8: StackMap locals: org.h2.mvstore.MVStore$ChunkIdsCollector long org.h2.mvstore.MVStore$ChunkIdsCollector
StackMap stack:
return
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
0 9 1 pos J
0 9 3 childCollector Lorg/h2/mvstore/MVStore$ChunkIdsCollector;
2 8 4 chunkIds [I
3 8 5 index I
5 6 6 chunkId Ljava/lang/Integer;
MethodParameters:
Name Flags
pos
childCollector
}
SourceFile: "MVStore.java"
NestHost: org.h2.mvstore.MVStore
InnerClasses:
public KeySetView = java.util.concurrent.ConcurrentHashMap$KeySetView of java.util.concurrent.ConcurrentHashMap
final ChunkIdsCollector = org.h2.mvstore.MVStore$ChunkIdsCollector of org.h2.mvstore.MVStore