public abstract class org.apache.logging.log4j.core.async.ThreadNameCachingStrategy extends java.lang.Enum<org.apache.logging.log4j.core.async.ThreadNameCachingStrategy>
  minor version: 0
  major version: 59
  flags: flags: (0x4421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT, ACC_ANNOTATION
  this_class: org.apache.logging.log4j.core.async.ThreadNameCachingStrategy
  super_class: java.lang.Enum
{
  public static final org.apache.logging.log4j.core.async.ThreadNameCachingStrategy CACHED;
    descriptor: Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    flags: (0x4019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL, ACC_ANNOTATION

  public static final org.apache.logging.log4j.core.async.ThreadNameCachingStrategy UNCACHED;
    descriptor: Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    flags: (0x4019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL, ACC_ANNOTATION

  private static final org.apache.logging.log4j.status.StatusLogger LOGGER;
    descriptor: Lorg/apache/logging/log4j/status/StatusLogger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.ThreadLocal<java.lang.String> THREADLOCAL_NAME;
    descriptor: Ljava/lang/ThreadLocal;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/lang/ThreadLocal<Ljava/lang/String;>;

  private static final org.apache.logging.log4j.core.async.ThreadNameCachingStrategy[] ENUM$VALUES;
    descriptor: [Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    flags: (0x101a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 27
            new org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$1
            dup
            ldc "CACHED"
            iconst_0
            invokespecial org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$1.<init>:(Ljava/lang/String;I)V
            putstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.CACHED:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
         1: .line 38
            new org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$2
            dup
            ldc "UNCACHED"
            iconst_1
            invokespecial org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$2.<init>:(Ljava/lang/String;I)V
            putstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.UNCACHED:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            iconst_2
            anewarray org.apache.logging.log4j.core.async.ThreadNameCachingStrategy
            dup
            iconst_0
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.CACHED:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            aastore
            dup
            iconst_1
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.UNCACHED:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            aastore
            putstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.ENUM$VALUES:[Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
         2: .line 45
            invokestatic org.apache.logging.log4j.status.StatusLogger.getLogger:()Lorg/apache/logging/log4j/status/StatusLogger;
            putstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
         3: .line 46
            new java.lang.ThreadLocal
            dup
            invokespecial java.lang.ThreadLocal.<init>:()V
            putstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.THREADLOCAL_NAME:Ljava/lang/ThreadLocal;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(java.lang.String, int);
    descriptor: (Ljava/lang/String;I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.logging.log4j.core.async.ThreadNameCachingStrategy this
         0: .line 26
            aload 0 /* this */
            aload 1
            iload 2
            invokespecial java.lang.Enum.<init>:(Ljava/lang/String;I)V
            return
        end local 0 // org.apache.logging.log4j.core.async.ThreadNameCachingStrategy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    MethodParameters:
               Name  Flags
      $enum$name     
      $enum$ordinal  

  abstract java.lang.String getThreadName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0400) ACC_ABSTRACT

  public static org.apache.logging.log4j.core.async.ThreadNameCachingStrategy create();
    descriptor: ()Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=0
         0: .line 51
            ldc "java.version"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            ldc "1.8.0_102"
            invokevirtual java.lang.String.compareTo:(Ljava/lang/String;)I
            ifge 2
         1: .line 52
            ldc "CACHED"
            goto 3
         2: .line 53
      StackMap locals:
      StackMap stack:
            ldc "UNCACHED"
         3: .line 51
      StackMap locals:
      StackMap stack: java.lang.String
            astore 0 /* defaultStrategy */
        start local 0 // java.lang.String defaultStrategy
         4: .line 54
            invokestatic org.apache.logging.log4j.util.PropertiesUtil.getProperties:()Lorg/apache/logging/log4j/util/PropertiesUtil;
            ldc "AsyncLogger.ThreadNameStrategy"
            invokevirtual org.apache.logging.log4j.util.PropertiesUtil.getStringProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* name */
        start local 1 // java.lang.String name
         5: .line 57
            aload 1 /* name */
            ifnull 6
            aload 1 /* name */
            goto 7
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
         6: aload 0 /* defaultStrategy */
         7: .line 56
      StackMap locals:
      StackMap stack: java.lang.String
            invokestatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.valueOf:(Ljava/lang/String;)Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            astore 2 /* result */
        start local 2 // org.apache.logging.log4j.core.async.ThreadNameCachingStrategy result
         8: .line 58
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
            ldc "AsyncLogger.ThreadNameStrategy={} (user specified {}, default is {})"
         9: .line 59
            aload 2 /* result */
            aload 1 /* name */
            aload 0 /* defaultStrategy */
        10: .line 58
            invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        11: .line 60
            aload 2 /* result */
        12: areturn
        end local 2 // org.apache.logging.log4j.core.async.ThreadNameCachingStrategy result
        13: .line 61
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 2 /* ex */
        start local 2 // java.lang.Exception ex
        14: .line 62
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
            ldc "Using AsyncLogger.ThreadNameStrategy.{}: '{}' not valid: {}"
        15: .line 63
            aload 0 /* defaultStrategy */
            aload 1 /* name */
            aload 2 /* ex */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
        16: .line 62
            invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        17: .line 64
            aload 0 /* defaultStrategy */
            invokestatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.valueOf:(Ljava/lang/String;)Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            areturn
        end local 2 // java.lang.Exception ex
        end local 1 // java.lang.String name
        end local 0 // java.lang.String defaultStrategy
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            4   18     0  defaultStrategy  Ljava/lang/String;
            5   18     1             name  Ljava/lang/String;
            8   13     2           result  Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
           14   18     2               ex  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           5    12      13  Class java.lang.Exception

  public static org.apache.logging.log4j.core.async.ThreadNameCachingStrategy[] values();
    descriptor: ()[Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=0
         0: .line 1
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.ENUM$VALUES:[Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            dup
            astore 0
            iconst_0
            aload 0
            arraylength
            dup
            istore 1
            anewarray org.apache.logging.log4j.core.async.ThreadNameCachingStrategy
            dup
            astore 2
            iconst_0
            iload 1
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
            aload 2
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static org.apache.logging.log4j.core.async.ThreadNameCachingStrategy valueOf(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
         0: .line 1
            ldc Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            aload 0
            invokestatic java.lang.Enum.valueOf:(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Enum;
            checkcast org.apache.logging.log4j.core.async.ThreadNameCachingStrategy
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    MethodParameters:
      Name  Flags
      name  
}
Signature: Ljava/lang/Enum<Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;>;
SourceFile: "ThreadNameCachingStrategy.java"
NestMembers:
  org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$1  org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$2
InnerClasses:
  org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$1
  org.apache.logging.log4j.core.async.ThreadNameCachingStrategy$2