public class org.apache.logging.log4j.message.ReusableObjectMessage implements org.apache.logging.log4j.message.ReusableMessage, org.apache.logging.log4j.message.ParameterVisitable, org.apache.logging.log4j.message.Clearable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.message.ReusableObjectMessage
  super_class: java.lang.Object
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 6922476812535519960

  private transient java.lang.Object obj;
    descriptor: Ljava/lang/Object;
    flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 27
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public void set(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
        start local 1 // java.lang.Object object
         0: .line 33
            aload 0 /* this */
            aload 1 /* object */
            putfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
         1: .line 34
            return
        end local 1 // java.lang.Object object
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;
            0    2     1  object  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      object  final

  public java.lang.String getFormattedMessage();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 43
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public void formatTo(java.lang.StringBuilder);
    descriptor: (Ljava/lang/StringBuilder;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
        start local 1 // java.lang.StringBuilder buffer
         0: .line 48
            aload 1 /* buffer */
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            invokestatic org.apache.logging.log4j.util.StringBuilders.appendValue:(Ljava/lang/StringBuilder;Ljava/lang/Object;)V
         1: .line 49
            return
        end local 1 // java.lang.StringBuilder buffer
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;
            0    2     1  buffer  Ljava/lang/StringBuilder;
    MethodParameters:
        Name  Flags
      buffer  final

  public java.lang.String getFormat();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 58
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            instanceof java.lang.String
            ifeq 1
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            checkcast java.lang.String
            goto 2
      StackMap locals:
      StackMap stack:
         1: aconst_null
      StackMap locals:
      StackMap stack: java.lang.String
         2: areturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public java.lang.Object getParameter();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 68
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            areturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public java.lang.Object[] getParameters();
    descriptor: ()[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 78
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            aastore
            areturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 83
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.message.ReusableObjectMessage.getFormattedMessage:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public java.lang.Throwable getThrowable();
    descriptor: ()Ljava/lang/Throwable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 93
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            instanceof java.lang.Throwable
            ifeq 1
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            checkcast java.lang.Throwable
            goto 2
      StackMap locals:
      StackMap stack:
         1: aconst_null
      StackMap locals:
      StackMap stack: java.lang.Throwable
         2: areturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public java.lang.Object[] swapParameters(java.lang.Object[]);
    descriptor: ([Ljava/lang/Object;)[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
        start local 1 // java.lang.Object[] emptyReplacement
         0: .line 106
            aload 1 /* emptyReplacement */
            arraylength
            ifne 4
         1: .line 107
            bipush 10
            anewarray java.lang.Object
            astore 2 /* params */
        start local 2 // java.lang.Object[] params
         2: .line 108
            aload 2 /* params */
            iconst_0
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            aastore
         3: .line 109
            aload 2 /* params */
            areturn
        end local 2 // java.lang.Object[] params
         4: .line 111
      StackMap locals:
      StackMap stack:
            aload 1 /* emptyReplacement */
            iconst_0
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            aastore
         5: .line 112
            aload 1 /* emptyReplacement */
            areturn
        end local 1 // java.lang.Object[] emptyReplacement
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    6     0              this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;
            0    6     1  emptyReplacement  [Ljava/lang/Object;
            2    4     2            params  [Ljava/lang/Object;
    MethodParameters:
                  Name  Flags
      emptyReplacement  final

  public short getParameterCount();
    descriptor: ()S
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 121
            iconst_1
            ireturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public <S> void forEachParameter(org.apache.logging.log4j.message.ParameterConsumer<S>, );
    descriptor: (Lorg/apache/logging/log4j/message/ParameterConsumer;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
        start local 1 // org.apache.logging.log4j.message.ParameterConsumer action
        start local 2 // java.lang.Object state
         0: .line 126
            aload 1 /* action */
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            iconst_0
            aload 2 /* state */
            invokeinterface org.apache.logging.log4j.message.ParameterConsumer.accept:(Ljava/lang/Object;ILjava/lang/Object;)V
         1: .line 127
            return
        end local 2 // java.lang.Object state
        end local 1 // org.apache.logging.log4j.message.ParameterConsumer action
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;
            0    2     1  action  Lorg/apache/logging/log4j/message/ParameterConsumer<TS;>;
            0    2     2   state  TS;
    Signature: <S:Ljava/lang/Object;>(Lorg/apache/logging/log4j/message/ParameterConsumer<TS;>;TS;)V
    MethodParameters:
        Name  Flags
      action  final
      state   final

  public org.apache.logging.log4j.message.Message memento();
    descriptor: ()Lorg/apache/logging/log4j/message/Message;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 131
            new org.apache.logging.log4j.message.ObjectMessage
            dup
            aload 0 /* this */
            getfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
            invokespecial org.apache.logging.log4j.message.ObjectMessage.<init>:(Ljava/lang/Object;)V
            areturn
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
         0: .line 136
            aload 0 /* this */
            aconst_null
            putfield org.apache.logging.log4j.message.ReusableObjectMessage.obj:Ljava/lang/Object;
         1: .line 137
            return
        end local 0 // org.apache.logging.log4j.message.ReusableObjectMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/message/ReusableObjectMessage;
}
SourceFile: "ReusableObjectMessage.java"
    RuntimeInvisibleAnnotations: 
      org.apache.logging.log4j.util.PerformanceSensitive(value = {"allocation"})