final class reactor.core.scheduler.PeriodicSchedulerTask implements java.lang.Runnable, reactor.core.Disposable, java.util.concurrent.Callable<java.lang.Void>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: reactor.core.scheduler.PeriodicSchedulerTask
super_class: java.lang.Object
{
final java.lang.Runnable task;
descriptor: Ljava/lang/Runnable;
flags: (0x0010) ACC_FINAL
static final java.util.concurrent.Future<java.lang.Void> CANCELLED;
descriptor: Ljava/util/concurrent/Future;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/Future<Ljava/lang/Void;>;
volatile java.util.concurrent.Future<?> future;
descriptor: Ljava/util/concurrent/Future;
flags: (0x0040) ACC_VOLATILE
Signature: Ljava/util/concurrent/Future<*>;
static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.scheduler.PeriodicSchedulerTask, java.util.concurrent.Future> FUTURE;
descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
flags: (0x0018) ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lreactor/core/scheduler/PeriodicSchedulerTask;Ljava/util/concurrent/Future;>;
java.lang.Thread thread;
descriptor: Ljava/lang/Thread;
flags: (0x0000)
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=0, args_size=0
0: new java.util.concurrent.FutureTask
dup
invokedynamic call()Ljava/util/concurrent/Callable;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
()Ljava/lang/Object;
reactor/core/scheduler/PeriodicSchedulerTask.lambda$0()Ljava/lang/Void; (6)
()Ljava/lang/Void;
invokespecial java.util.concurrent.FutureTask.<init>:(Ljava/util/concurrent/Callable;)V
putstatic reactor.core.scheduler.PeriodicSchedulerTask.CANCELLED:Ljava/util/concurrent/Future;
1: ldc Lreactor/core/scheduler/PeriodicSchedulerTask;
ldc Ljava/util/concurrent/Future;
ldc "future"
invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
2: putstatic reactor.core.scheduler.PeriodicSchedulerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
3: return
LocalVariableTable:
Start End Slot Name Signature
void <init>(java.lang.Runnable);
descriptor: (Ljava/lang/Runnable;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 1
putfield reactor.core.scheduler.PeriodicSchedulerTask.task:Ljava/lang/Runnable;
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lreactor/core/scheduler/PeriodicSchedulerTask;
0 3 1 task Ljava/lang/Runnable;
MethodParameters:
Name Flags
task
public java.lang.Void call();
descriptor: ()Ljava/lang/Void;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=1
start local 0 0: aload 0
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
putfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
1: aload 0
getfield reactor.core.scheduler.PeriodicSchedulerTask.task:Ljava/lang/Runnable;
invokeinterface java.lang.Runnable.run:()V
2: goto 9
3: StackMap locals:
StackMap stack: java.lang.Throwable
astore 1
start local 1 4: aload 1
invokestatic reactor.core.scheduler.Schedulers.handleError:(Ljava/lang/Throwable;)V
end local 1 5: goto 9
6: StackMap locals:
StackMap stack: java.lang.Throwable
astore 2
7: aload 0
aconst_null
putfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
8: aload 2
athrow
9: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
10: aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lreactor/core/scheduler/PeriodicSchedulerTask;
4 5 1 ex Ljava/lang/Throwable;
Exception table:
from to target type
1 2 3 Class java.lang.Throwable
1 6 6 any
RuntimeVisibleAnnotations:
reactor.util.annotation.Nullable()
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual reactor.core.scheduler.PeriodicSchedulerTask.call:()Ljava/lang/Void;
pop
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lreactor/core/scheduler/PeriodicSchedulerTask;
void setFuture(java.util.concurrent.Future<?>);
descriptor: (Ljava/util/concurrent/Future;)V
flags: (0x0000)
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.scheduler.PeriodicSchedulerTask.future:Ljava/util/concurrent/Future;
astore 2
start local 2 1: aload 2
getstatic reactor.core.scheduler.PeriodicSchedulerTask.CANCELLED:Ljava/util/concurrent/Future;
if_acmpne 6
2: aload 1
aload 0
getfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
if_acmpeq 3
iconst_1
goto 4
StackMap locals: reactor.core.scheduler.PeriodicSchedulerTask java.util.concurrent.Future java.util.concurrent.Future
StackMap stack: java.util.concurrent.Future
3: iconst_0
StackMap locals: reactor.core.scheduler.PeriodicSchedulerTask java.util.concurrent.Future java.util.concurrent.Future
StackMap stack: java.util.concurrent.Future int
4: invokeinterface java.util.concurrent.Future.cancel:(Z)Z
pop
5: return
6: StackMap locals:
StackMap stack:
getstatic reactor.core.scheduler.PeriodicSchedulerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
aload 0
aload 2
aload 1
invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 0
7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lreactor/core/scheduler/PeriodicSchedulerTask;
0 8 1 f Ljava/util/concurrent/Future<*>;
1 8 2 o Ljava/util/concurrent/Future;
Signature: (Ljava/util/concurrent/Future<*>;)V
MethodParameters:
Name Flags
f
public boolean isDisposed();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield reactor.core.scheduler.PeriodicSchedulerTask.future:Ljava/util/concurrent/Future;
getstatic reactor.core.scheduler.PeriodicSchedulerTask.CANCELLED:Ljava/util/concurrent/Future;
if_acmpne 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 Lreactor/core/scheduler/PeriodicSchedulerTask;
public void dispose();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=1
start local 0 0: StackMap locals:
StackMap stack:
aload 0
getfield reactor.core.scheduler.PeriodicSchedulerTask.future:Ljava/util/concurrent/Future;
astore 1
start local 1 1: aload 1
getstatic reactor.core.scheduler.PeriodicSchedulerTask.CANCELLED:Ljava/util/concurrent/Future;
if_acmpne 3
2: goto 8
3: StackMap locals: java.util.concurrent.Future
StackMap stack:
getstatic reactor.core.scheduler.PeriodicSchedulerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
aload 0
aload 1
getstatic reactor.core.scheduler.PeriodicSchedulerTask.CANCELLED:Ljava/util/concurrent/Future;
invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 0
4: aload 1
ifnull 8
5: aload 1
aload 0
getfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
if_acmpeq 6
iconst_1
goto 7
StackMap locals:
StackMap stack: java.util.concurrent.Future
6: iconst_0
StackMap locals: reactor.core.scheduler.PeriodicSchedulerTask java.util.concurrent.Future
StackMap stack: java.util.concurrent.Future int
7: invokeinterface java.util.concurrent.Future.cancel:(Z)Z
pop
end local 1 8: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lreactor/core/scheduler/PeriodicSchedulerTask;
1 8 1 f Ljava/util/concurrent/Future;
public java.lang.Object call();
descriptor: ()Ljava/lang/Object;
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=1, locals=1, args_size=1
0: aload 0
invokevirtual reactor.core.scheduler.PeriodicSchedulerTask.call:()Ljava/lang/Void;
areturn
LocalVariableTable:
Start End Slot Name Signature
Exceptions:
throws java.lang.Exception
private static java.lang.Void lambda$0();
descriptor: ()Ljava/lang/Void;
flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
Code:
stack=1, locals=0, args_size=0
0: aconst_null
areturn
LocalVariableTable:
Start End Slot Name Signature
Exceptions:
throws java.lang.Exception
}
Signature: Ljava/lang/Object;Ljava/lang/Runnable;Lreactor/core/Disposable;Ljava/util/concurrent/Callable<Ljava/lang/Void;>;
SourceFile: "PeriodicSchedulerTask.java"
InnerClasses:
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles