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: .line 31
            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: .line 35
            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: .line 34
            putstatic reactor.core.scheduler.PeriodicSchedulerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         3: .line 35
            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 // reactor.core.scheduler.PeriodicSchedulerTask this
        start local 1 // java.lang.Runnable task
         0: .line 39
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 40
            aload 0 /* this */
            aload 1 /* task */
            putfield reactor.core.scheduler.PeriodicSchedulerTask.task:Ljava/lang/Runnable;
         2: .line 41
            return
        end local 1 // java.lang.Runnable task
        end local 0 // reactor.core.scheduler.PeriodicSchedulerTask this
      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 // reactor.core.scheduler.PeriodicSchedulerTask this
         0: .line 46
            aload 0 /* this */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            putfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
         1: .line 49
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicSchedulerTask.task:Ljava/lang/Runnable;
            invokeinterface java.lang.Runnable.run:()V
         2: .line 50
            goto 9
         3: .line 51
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1 /* ex */
        start local 1 // java.lang.Throwable ex
         4: .line 52
            aload 1 /* ex */
            invokestatic reactor.core.scheduler.Schedulers.handleError:(Ljava/lang/Throwable;)V
        end local 1 // java.lang.Throwable ex
         5: .line 54
            goto 9
         6: .line 55
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         7: .line 56
            aload 0 /* this */
            aconst_null
            putfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
         8: .line 57
            aload 2
            athrow
         9: .line 56
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield reactor.core.scheduler.PeriodicSchedulerTask.thread:Ljava/lang/Thread;
        10: .line 58
            aconst_null
            areturn
        end local 0 // reactor.core.scheduler.PeriodicSchedulerTask this
      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 // reactor.core.scheduler.PeriodicSchedulerTask this
         0: .line 63
            aload 0 /* this */
            invokevirtual reactor.core.scheduler.PeriodicSchedulerTask.call:()Ljava/lang/Void;
            pop
         1: .line 64
            return
        end local 0 // reactor.core.scheduler.PeriodicSchedulerTask this
      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 // reactor.core.scheduler.PeriodicSchedulerTask this
        start local 1 // java.util.concurrent.Future f
         0: .line 68
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicSchedulerTask.future:Ljava/util/concurrent/Future;
            astore 2 /* o */
        start local 2 // java.util.concurrent.Future o
         1: .line 69
            aload 2 /* o */
            getstatic reactor.core.scheduler.PeriodicSchedulerTask.CANCELLED:Ljava/util/concurrent/Future;
            if_acmpne 6
         2: .line 70
            aload 1 /* f */
            aload 0 /* this */
            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: .line 71
            return
         6: .line 73
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.scheduler.PeriodicSchedulerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 2 /* o */
            aload 1 /* f */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 0
         7: .line 74
            return
        end local 2 // java.util.concurrent.Future o
        end local 1 // java.util.concurrent.Future f
        end local 0 // reactor.core.scheduler.PeriodicSchedulerTask this
      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 // reactor.core.scheduler.PeriodicSchedulerTask this
         0: .line 81
            aload 0 /* this */
            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 // reactor.core.scheduler.PeriodicSchedulerTask this
      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 // reactor.core.scheduler.PeriodicSchedulerTask this
         0: .line 87
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicSchedulerTask.future:Ljava/util/concurrent/Future;
            astore 1 /* f */
        start local 1 // java.util.concurrent.Future f
         1: .line 88
            aload 1 /* f */
            getstatic reactor.core.scheduler.PeriodicSchedulerTask.CANCELLED:Ljava/util/concurrent/Future;
            if_acmpne 3
         2: .line 89
            goto 8
         3: .line 91
      StackMap locals: java.util.concurrent.Future
      StackMap stack:
            getstatic reactor.core.scheduler.PeriodicSchedulerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 1 /* f */
            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: .line 92
            aload 1 /* f */
            ifnull 8
         5: .line 93
            aload 1 /* f */
            aload 0 /* this */
            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 // java.util.concurrent.Future f
         8: .line 98
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.scheduler.PeriodicSchedulerTask this
      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: .line 1
            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: .line 31
            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