public class org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent
  super_class: java.lang.Object
{
  private final org.springframework.core.metrics.StartupStep startupStep;
    descriptor: Lorg/springframework/core/metrics/StartupStep;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.time.Instant startTime;
    descriptor: Ljava/time/Instant;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.time.Instant endTime;
    descriptor: Ljava/time/Instant;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.time.Duration duration;
    descriptor: Ljava/time/Duration;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(org.springframework.boot.context.metrics.buffering.BufferedStartupStep, java.time.Instant, long);
    descriptor: (Lorg/springframework/boot/context/metrics/buffering/BufferedStartupStep;Ljava/time/Instant;J)V
    flags: (0x0000) 
    Code:
      stack=6, locals=5, args_size=4
        start local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
        start local 1 // org.springframework.boot.context.metrics.buffering.BufferedStartupStep startupStep
        start local 2 // java.time.Instant startupDate
        start local 3 // long startupNanoTime
         0: .line 78
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 79
            aload 0 /* this */
            aload 1 /* startupStep */
            putfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.startupStep:Lorg/springframework/core/metrics/StartupStep;
         2: .line 80
            aload 0 /* this */
            aload 2 /* startupDate */
            aload 1 /* startupStep */
            invokevirtual org.springframework.boot.context.metrics.buffering.BufferedStartupStep.getStartTime:()J
            lload 3 /* startupNanoTime */
            lsub
            invokestatic java.time.Duration.ofNanos:(J)Ljava/time/Duration;
            invokevirtual java.time.Instant.plus:(Ljava/time/temporal/TemporalAmount;)Ljava/time/Instant;
            putfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.startTime:Ljava/time/Instant;
         3: .line 81
            aload 0 /* this */
            aload 2 /* startupDate */
            aload 1 /* startupStep */
            invokevirtual org.springframework.boot.context.metrics.buffering.BufferedStartupStep.getEndTime:()J
            lload 3 /* startupNanoTime */
            lsub
            invokestatic java.time.Duration.ofNanos:(J)Ljava/time/Duration;
            invokevirtual java.time.Instant.plus:(Ljava/time/temporal/TemporalAmount;)Ljava/time/Instant;
            putfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.endTime:Ljava/time/Instant;
         4: .line 82
            aload 0 /* this */
            aload 1 /* startupStep */
            invokevirtual org.springframework.boot.context.metrics.buffering.BufferedStartupStep.getEndTime:()J
            aload 1 /* startupStep */
            invokevirtual org.springframework.boot.context.metrics.buffering.BufferedStartupStep.getStartTime:()J
            lsub
            invokestatic java.time.Duration.ofNanos:(J)Ljava/time/Duration;
            putfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.duration:Ljava/time/Duration;
         5: .line 83
            return
        end local 3 // long startupNanoTime
        end local 2 // java.time.Instant startupDate
        end local 1 // org.springframework.boot.context.metrics.buffering.BufferedStartupStep startupStep
        end local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    6     0             this  Lorg/springframework/boot/context/metrics/buffering/StartupTimeline$TimelineEvent;
            0    6     1      startupStep  Lorg/springframework/boot/context/metrics/buffering/BufferedStartupStep;
            0    6     2      startupDate  Ljava/time/Instant;
            0    6     3  startupNanoTime  J
    MethodParameters:
                 Name  Flags
      startupStep      
      startupDate      
      startupNanoTime  

  public java.time.Instant getStartTime();
    descriptor: ()Ljava/time/Instant;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
         0: .line 90
            aload 0 /* this */
            getfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.startTime:Ljava/time/Instant;
            areturn
        end local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/springframework/boot/context/metrics/buffering/StartupTimeline$TimelineEvent;

  public java.time.Instant getEndTime();
    descriptor: ()Ljava/time/Instant;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
         0: .line 98
            aload 0 /* this */
            getfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.endTime:Ljava/time/Instant;
            areturn
        end local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/springframework/boot/context/metrics/buffering/StartupTimeline$TimelineEvent;

  public java.time.Duration getDuration();
    descriptor: ()Ljava/time/Duration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
         0: .line 107
            aload 0 /* this */
            getfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.duration:Ljava/time/Duration;
            areturn
        end local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/springframework/boot/context/metrics/buffering/StartupTimeline$TimelineEvent;

  public org.springframework.core.metrics.StartupStep getStartupStep();
    descriptor: ()Lorg/springframework/core/metrics/StartupStep;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
         0: .line 115
            aload 0 /* this */
            getfield org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent.startupStep:Lorg/springframework/core/metrics/StartupStep;
            areturn
        end local 0 // org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/springframework/boot/context/metrics/buffering/StartupTimeline$TimelineEvent;
}
SourceFile: "StartupTimeline.java"
NestHost: org.springframework.boot.context.metrics.buffering.StartupTimeline
InnerClasses:
  public TimelineEvent = org.springframework.boot.context.metrics.buffering.StartupTimeline$TimelineEvent of org.springframework.boot.context.metrics.buffering.StartupTimeline