final class io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker extends io.reactivex.Scheduler$Worker implements io.reactivex.disposables.Disposable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker
  super_class: io.reactivex.Scheduler$Worker
{
  final java.util.concurrent.PriorityBlockingQueue<io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable> queue;
    descriptor: Ljava/util/concurrent/PriorityBlockingQueue;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/concurrent/PriorityBlockingQueue<Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;>;

  private final java.util.concurrent.atomic.AtomicInteger wip;
    descriptor: Ljava/util/concurrent/atomic/AtomicInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  final java.util.concurrent.atomic.AtomicInteger counter;
    descriptor: Ljava/util/concurrent/atomic/AtomicInteger;
    flags: (0x0010) ACC_FINAL

  volatile boolean disposed;
    descriptor: Z
    flags: (0x0040) ACC_VOLATILE

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
         0: .line 69
            aload 0 /* this */
            invokespecial io.reactivex.Scheduler$Worker.<init>:()V
         1: .line 70
            aload 0 /* this */
            new java.util.concurrent.PriorityBlockingQueue
            dup
            invokespecial java.util.concurrent.PriorityBlockingQueue.<init>:()V
            putfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.queue:Ljava/util/concurrent/PriorityBlockingQueue;
         2: .line 72
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
            putfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.wip:Ljava/util/concurrent/atomic/AtomicInteger;
         3: .line 74
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
            putfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.counter:Ljava/util/concurrent/atomic/AtomicInteger;
         4: .line 69
            return
        end local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;

  public io.reactivex.disposables.Disposable schedule(java.lang.Runnable);
    descriptor: (Ljava/lang/Runnable;)Lio/reactivex/disposables/Disposable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
        start local 1 // java.lang.Runnable action
         0: .line 81
            aload 0 /* this */
            aload 1 /* action */
            aload 0 /* this */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.now:(Ljava/util/concurrent/TimeUnit;)J
            invokevirtual io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.enqueue:(Ljava/lang/Runnable;J)Lio/reactivex/disposables/Disposable;
            areturn
        end local 1 // java.lang.Runnable action
        end local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;
            0    1     1  action  Ljava/lang/Runnable;
    RuntimeInvisibleAnnotations: 
      io.reactivex.annotations.NonNull()
    RuntimeInvisibleParameterAnnotations: 
      0:
        io.reactivex.annotations.NonNull()
    MethodParameters:
        Name  Flags
      action  

  public io.reactivex.disposables.Disposable schedule(java.lang.Runnable, long, java.util.concurrent.TimeUnit);
    descriptor: (Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=7, args_size=4
        start local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
        start local 1 // java.lang.Runnable action
        start local 2 // long delayTime
        start local 4 // java.util.concurrent.TimeUnit unit
         0: .line 87
            aload 0 /* this */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.now:(Ljava/util/concurrent/TimeUnit;)J
            aload 4 /* unit */
            lload 2 /* delayTime */
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            ladd
            lstore 5 /* execTime */
        start local 5 // long execTime
         1: .line 89
            aload 0 /* this */
            new io.reactivex.internal.schedulers.TrampolineScheduler$SleepingRunnable
            dup
            aload 1 /* action */
            aload 0 /* this */
            lload 5 /* execTime */
            invokespecial io.reactivex.internal.schedulers.TrampolineScheduler$SleepingRunnable.<init>:(Ljava/lang/Runnable;Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;J)V
            lload 5 /* execTime */
            invokevirtual io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.enqueue:(Ljava/lang/Runnable;J)Lio/reactivex/disposables/Disposable;
            areturn
        end local 5 // long execTime
        end local 4 // java.util.concurrent.TimeUnit unit
        end local 2 // long delayTime
        end local 1 // java.lang.Runnable action
        end local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;
            0    2     1     action  Ljava/lang/Runnable;
            0    2     2  delayTime  J
            0    2     4       unit  Ljava/util/concurrent/TimeUnit;
            1    2     5   execTime  J
    RuntimeInvisibleAnnotations: 
      io.reactivex.annotations.NonNull()
    RuntimeInvisibleParameterAnnotations: 
      0:
        io.reactivex.annotations.NonNull()
      1:
      2:
        io.reactivex.annotations.NonNull()
    MethodParameters:
           Name  Flags
      action     
      delayTime  
      unit       

  io.reactivex.disposables.Disposable enqueue(java.lang.Runnable, long);
    descriptor: (Ljava/lang/Runnable;J)Lio/reactivex/disposables/Disposable;
    flags: (0x0000) 
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
        start local 1 // java.lang.Runnable action
        start local 2 // long execTime
         0: .line 93
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.disposed:Z
            ifeq 2
         1: .line 94
            getstatic io.reactivex.internal.disposables.EmptyDisposable.INSTANCE:Lio/reactivex/internal/disposables/EmptyDisposable;
            areturn
         2: .line 96
      StackMap locals:
      StackMap stack:
            new io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable
            dup
            aload 1 /* action */
            lload 2 /* execTime */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.counter:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.incrementAndGet:()I
            invokespecial io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable.<init>:(Ljava/lang/Runnable;Ljava/lang/Long;I)V
            astore 4 /* timedRunnable */
        start local 4 // io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable timedRunnable
         3: .line 97
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.queue:Ljava/util/concurrent/PriorityBlockingQueue;
            aload 4 /* timedRunnable */
            invokevirtual java.util.concurrent.PriorityBlockingQueue.add:(Ljava/lang/Object;)Z
            pop
         4: .line 99
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.wip:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndIncrement:()I
            ifne 18
         5: .line 100
            iconst_1
            istore 5 /* missed */
        start local 5 // int missed
         6: .line 103
      StackMap locals: io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable int
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.disposed:Z
            ifeq 9
         7: .line 104
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.queue:Ljava/util/concurrent/PriorityBlockingQueue;
            invokevirtual java.util.concurrent.PriorityBlockingQueue.clear:()V
         8: .line 105
            getstatic io.reactivex.internal.disposables.EmptyDisposable.INSTANCE:Lio/reactivex/internal/disposables/EmptyDisposable;
            areturn
         9: .line 107
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.queue:Ljava/util/concurrent/PriorityBlockingQueue;
            invokevirtual java.util.concurrent.PriorityBlockingQueue.poll:()Ljava/lang/Object;
            checkcast io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable
            astore 6 /* polled */
        start local 6 // io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable polled
        10: .line 108
            aload 6 /* polled */
            ifnonnull 12
        11: .line 109
            goto 15
        12: .line 111
      StackMap locals: io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable
      StackMap stack:
            aload 6 /* polled */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable.disposed:Z
            ifne 6
        13: .line 112
            aload 6 /* polled */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable.run:Ljava/lang/Runnable;
            invokeinterface java.lang.Runnable.run:()V
        end local 6 // io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable polled
        14: .line 102
            goto 6
        15: .line 115
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.wip:Ljava/util/concurrent/atomic/AtomicInteger;
            iload 5 /* missed */
            ineg
            invokevirtual java.util.concurrent.atomic.AtomicInteger.addAndGet:(I)I
            istore 5 /* missed */
        16: .line 116
            iload 5 /* missed */
            ifne 6
        17: .line 121
            getstatic io.reactivex.internal.disposables.EmptyDisposable.INSTANCE:Lio/reactivex/internal/disposables/EmptyDisposable;
            areturn
        end local 5 // int missed
        18: .line 124
      StackMap locals:
      StackMap stack:
            new io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker$AppendToQueueTask
            dup
            aload 0 /* this */
            aload 4 /* timedRunnable */
            invokespecial io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker$AppendToQueueTask.<init>:(Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;)V
            invokestatic io.reactivex.disposables.Disposables.fromRunnable:(Ljava/lang/Runnable;)Lio/reactivex/disposables/Disposable;
            areturn
        end local 4 // io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable timedRunnable
        end local 2 // long execTime
        end local 1 // java.lang.Runnable action
        end local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   19     0           this  Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;
            0   19     1         action  Ljava/lang/Runnable;
            0   19     2       execTime  J
            3   19     4  timedRunnable  Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
            6   18     5         missed  I
           10   14     6         polled  Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
    MethodParameters:
          Name  Flags
      action    
      execTime  

  public void dispose();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
         0: .line 130
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.disposed:Z
         1: .line 131
            return
        end local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;

  public boolean isDisposed();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
         0: .line 135
            aload 0 /* this */
            getfield io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker.disposed:Z
            ireturn
        end local 0 // io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;
}
SourceFile: "TrampolineScheduler.java"
NestHost: io.reactivex.internal.schedulers.TrampolineScheduler
InnerClasses:
  public abstract Worker = io.reactivex.Scheduler$Worker of io.reactivex.Scheduler
  final SleepingRunnable = io.reactivex.internal.schedulers.TrampolineScheduler$SleepingRunnable of io.reactivex.internal.schedulers.TrampolineScheduler
  final TimedRunnable = io.reactivex.internal.schedulers.TrampolineScheduler$TimedRunnable of io.reactivex.internal.schedulers.TrampolineScheduler
  final TrampolineWorker = io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker of io.reactivex.internal.schedulers.TrampolineScheduler
  final AppendToQueueTask = io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker$AppendToQueueTask of io.reactivex.internal.schedulers.TrampolineScheduler$TrampolineWorker