class java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask<V> extends java.util.concurrent.FutureTask<V> implements java.util.concurrent.RunnableScheduledFuture<V>
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask
super_class: java.util.concurrent.FutureTask
{
private final long sequenceNumber;
descriptor: J
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private long time;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private final long period;
descriptor: J
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
java.util.concurrent.RunnableScheduledFuture<V> outerTask;
descriptor: Ljava/util/concurrent/RunnableScheduledFuture;
flags: (0x0000)
Signature: Ljava/util/concurrent/RunnableScheduledFuture<TV;>;
int heapIndex;
descriptor: I
flags: (0x0000)
final java.util.concurrent.ScheduledThreadPoolExecutor this$0;
descriptor: Ljava/util/concurrent/ScheduledThreadPoolExecutor;
flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC
void <init>(java.lang.Runnable, V, );
descriptor: (Ljava/util/concurrent/ScheduledThreadPoolExecutor;Ljava/lang/Runnable;Ljava/lang/Object;J)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=5
start local 0 start local 2 start local 3 start local 4 0: aload 0
aload 1
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
1: aload 0
aload 2
aload 3
invokespecial java.util.concurrent.FutureTask.<init>:(Ljava/lang/Runnable;Ljava/lang/Object;)V
2: aload 0
aload 0
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.outerTask:Ljava/util/concurrent/RunnableScheduledFuture;
3: aload 0
lload 4
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
4: aload 0
lconst_0
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.period:J
5: aload 0
getstatic java.util.concurrent.ScheduledThreadPoolExecutor.sequencer:Ljava/util/concurrent/atomic/AtomicLong;
invokevirtual java.util.concurrent.atomic.AtomicLong.getAndIncrement:()J
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.sequenceNumber:J
6: return
end local 4 end local 3 end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
0 7 2 r Ljava/lang/Runnable;
0 7 3 result TV;
0 7 4 ns J
Signature: (Ljava/lang/Runnable;TV;J)V
MethodParameters:
Name Flags
this$0 final
r
result
ns
void <init>(java.lang.Runnable, V, long, );
descriptor: (Ljava/util/concurrent/ScheduledThreadPoolExecutor;Ljava/lang/Runnable;Ljava/lang/Object;JJ)V
flags: (0x0000)
Code:
stack=3, locals=8, args_size=6
start local 0 start local 2 start local 3 start local 4 start local 6 0: aload 0
aload 1
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
1: aload 0
aload 2
aload 3
invokespecial java.util.concurrent.FutureTask.<init>:(Ljava/lang/Runnable;Ljava/lang/Object;)V
2: aload 0
aload 0
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.outerTask:Ljava/util/concurrent/RunnableScheduledFuture;
3: aload 0
lload 4
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
4: aload 0
lload 6
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.period:J
5: aload 0
getstatic java.util.concurrent.ScheduledThreadPoolExecutor.sequencer:Ljava/util/concurrent/atomic/AtomicLong;
invokevirtual java.util.concurrent.atomic.AtomicLong.getAndIncrement:()J
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.sequenceNumber:J
6: return
end local 6 end local 4 end local 3 end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
0 7 2 r Ljava/lang/Runnable;
0 7 3 result TV;
0 7 4 ns J
0 7 6 period J
Signature: (Ljava/lang/Runnable;TV;JJ)V
MethodParameters:
Name Flags
this$0 final
r
result
ns
period
void <init>(java.util.concurrent.Callable<V>, );
descriptor: (Ljava/util/concurrent/ScheduledThreadPoolExecutor;Ljava/util/concurrent/Callable;J)V
flags: (0x0000)
Code:
stack=3, locals=5, args_size=4
start local 0 start local 2 start local 3 0: aload 0
aload 1
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
1: aload 0
aload 2
invokespecial java.util.concurrent.FutureTask.<init>:(Ljava/util/concurrent/Callable;)V
2: aload 0
aload 0
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.outerTask:Ljava/util/concurrent/RunnableScheduledFuture;
3: aload 0
lload 3
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
4: aload 0
lconst_0
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.period:J
5: aload 0
getstatic java.util.concurrent.ScheduledThreadPoolExecutor.sequencer:Ljava/util/concurrent/atomic/AtomicLong;
invokevirtual java.util.concurrent.atomic.AtomicLong.getAndIncrement:()J
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.sequenceNumber:J
6: return
end local 3 end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
0 7 2 callable Ljava/util/concurrent/Callable<TV;>;
0 7 3 ns J
Signature: (Ljava/util/concurrent/Callable<TV;>;J)V
MethodParameters:
Name Flags
this$0 final
callable
ns
public long getDelay(java.util.concurrent.TimeUnit);
descriptor: (Ljava/util/concurrent/TimeUnit;)J
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 1
aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor.now:()J
lsub
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
lreturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
0 1 1 unit Ljava/util/concurrent/TimeUnit;
MethodParameters:
Name Flags
unit
public int compareTo(java.util.concurrent.Delayed);
descriptor: (Ljava/util/concurrent/Delayed;)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=5, args_size=2
start local 0 start local 1 0: aload 1
aload 0
if_acmpne 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 1
instanceof java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask
ifeq 12
3: aload 1
checkcast java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask
astore 2
start local 2 4: aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
aload 2
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
lsub
lstore 3
start local 3 5: lload 3
lconst_0
lcmp
ifge 7
6: iconst_m1
ireturn
7: StackMap locals: java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask long
StackMap stack:
lload 3
lconst_0
lcmp
ifle 9
8: iconst_1
ireturn
9: StackMap locals:
StackMap stack:
aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.sequenceNumber:J
aload 2
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.sequenceNumber:J
lcmp
ifge 11
10: iconst_m1
ireturn
11: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 3 end local 2 12: StackMap locals:
StackMap stack:
aload 0
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.getDelay:(Ljava/util/concurrent/TimeUnit;)J
aload 1
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokeinterface java.util.concurrent.Delayed.getDelay:(Ljava/util/concurrent/TimeUnit;)J
lsub
lstore 2
start local 2 13: lload 2
lconst_0
lcmp
ifge 14
iconst_m1
goto 16
StackMap locals: long
StackMap stack:
14: lload 2
lconst_0
lcmp
ifle 15
iconst_1
goto 16
StackMap locals:
StackMap stack:
15: iconst_0
StackMap locals:
StackMap stack: int
16: ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
0 17 1 other Ljava/util/concurrent/Delayed;
4 12 2 x Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<*>;
5 12 3 diff J
13 17 2 diff J
MethodParameters:
Name Flags
other
public boolean isPeriodic();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.period:J
lconst_0
lcmp
ifeq 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
private void setNextRunTime();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=3, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.period:J
lstore 1
start local 1 1: lload 1
lconst_0
lcmp
ifle 3
2: aload 0
dup
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
lload 1
ladd
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
goto 4
3: StackMap locals: long
StackMap stack:
aload 0
aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
lload 1
lneg
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor.triggerTime:(J)J
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.time:J
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
1 5 1 p J
public boolean cancel(boolean);
descriptor: (Z)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
iload 1
invokespecial java.util.concurrent.FutureTask.cancel:(Z)Z
istore 2
start local 2 1: iload 2
ifeq 3
aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
getfield java.util.concurrent.ScheduledThreadPoolExecutor.removeOnCancel:Z
ifeq 3
aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.heapIndex:I
iflt 3
2: aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
aload 0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor.remove:(Ljava/lang/Runnable;)Z
pop
3: StackMap locals: int
StackMap stack:
iload 2
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
0 4 1 mayInterruptIfRunning Z
1 4 2 cancelled Z
MethodParameters:
Name Flags
mayInterruptIfRunning
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.isPeriodic:()Z
istore 1
start local 1 1: aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
iload 1
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor.canRunInCurrentRunState:(Z)Z
ifne 3
2: aload 0
iconst_0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.cancel:(Z)Z
pop
goto 8
3: StackMap locals: int
StackMap stack:
iload 1
ifne 5
4: aload 0
invokestatic java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$1:(Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask;)V
goto 8
5: StackMap locals:
StackMap stack:
aload 0
invokestatic java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$2:(Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask;)Z
ifeq 8
6: aload 0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.setNextRunTime:()V
7: aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.outerTask:Ljava/util/concurrent/RunnableScheduledFuture;
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor.reExecutePeriodic:(Ljava/util/concurrent/RunnableScheduledFuture;)V
8: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
1 9 1 periodic Z
public int compareTo(java.lang.Object);
descriptor: (Ljava/lang/Object;)I
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
0: aload 0
aload 1
checkcast java.util.concurrent.Delayed
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.compareTo:(Ljava/util/concurrent/Delayed;)I
ireturn
LocalVariableTable:
Start End Slot Name Signature
static void access$1(java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask);
descriptor: (Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask;)V
flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokespecial java.util.concurrent.FutureTask.run:()V
return
LocalVariableTable:
Start End Slot Name Signature
static boolean access$2(java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask);
descriptor: (Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask;)Z
flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokespecial java.util.concurrent.FutureTask.runAndReset:()Z
ireturn
LocalVariableTable:
Start End Slot Name Signature
}
Signature: <V:Ljava/lang/Object;>Ljava/util/concurrent/FutureTask<TV;>;Ljava/util/concurrent/RunnableScheduledFuture<TV;>;
SourceFile: "ScheduledThreadPoolExecutor.java"
NestHost: java.util.concurrent.ScheduledThreadPoolExecutor
InnerClasses:
private ScheduledFutureTask = java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask of java.util.concurrent.ScheduledThreadPoolExecutor