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 volatile long time;
descriptor: J
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
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, 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
lconst_0
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.period:J
5: aload 0
lload 6
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 triggerTime J
0 7 6 sequenceNumber J
Signature: (Ljava/lang/Runnable;TV;JJ)V
MethodParameters:
Name Flags
this$0 final
r
result
triggerTime
sequenceNumber
void <init>(java.lang.Runnable, V, long, long, );
descriptor: (Ljava/util/concurrent/ScheduledThreadPoolExecutor;Ljava/lang/Runnable;Ljava/lang/Object;JJJ)V
flags: (0x0000)
Code:
stack=3, locals=10, args_size=7
start local 0 start local 2 start local 3 start local 4 start local 6 start local 8 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
lload 8
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.sequenceNumber:J
6: return
end local 8 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 triggerTime J
0 7 6 period J
0 7 8 sequenceNumber J
Signature: (Ljava/lang/Runnable;TV;JJJ)V
MethodParameters:
Name Flags
this$0 final
r
result
triggerTime
period
sequenceNumber
void <init>(java.util.concurrent.Callable<V>, long, );
descriptor: (Ljava/util/concurrent/ScheduledThreadPoolExecutor;Ljava/util/concurrent/Callable;JJ)V
flags: (0x0000)
Code:
stack=3, locals=7, args_size=5
start local 0 start local 2 start local 3 start local 5 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
lload 5
putfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.sequenceNumber:J
6: return
end local 5 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 triggerTime J
0 7 5 sequenceNumber J
Signature: (Ljava/util/concurrent/Callable<TV;>;JJ)V
MethodParameters:
Name Flags
this$0 final
callable
triggerTime
sequenceNumber
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
invokestatic java.lang.System.nanoTime:()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=1, args_size=1
start local 0 0: aload 0
getfield java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.this$0:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
aload 0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor.canRunInCurrentRunState:(Ljava/util/concurrent/RunnableScheduledFuture;)Z
ifne 2
1: aload 0
iconst_0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.cancel:(Z)Z
pop
goto 7
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.isPeriodic:()Z
ifne 4
3: aload 0
invokespecial java.util.concurrent.FutureTask.run:()V
goto 7
4: StackMap locals:
StackMap stack:
aload 0
invokespecial java.util.concurrent.FutureTask.runAndReset:()Z
ifeq 7
5: aload 0
invokevirtual java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.setNextRunTime:()V
6: 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
7: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Ljava/util/concurrent/ScheduledThreadPoolExecutor$ScheduledFutureTask<TV;>;
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
}
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