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;>;

  static final org.apache.logging.log4j.core.async.ThreadNameCachingStrategy DEFAULT_STRATEGY;
    descriptor: Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  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 31
            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 42
            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 49
            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 50
            new java.lang.ThreadLocal
            dup
            invokespecial java.lang.ThreadLocal.<init>:()V
            putstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.THREADLOCAL_NAME:Ljava/lang/ThreadLocal;
         4: .line 51
            invokestatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.isAllocatingThreadGetName:()Z
            ifeq 5
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.CACHED:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            goto 6
      StackMap locals:
      StackMap stack:
         5: getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.UNCACHED:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
      StackMap locals:
      StackMap stack: org.apache.logging.log4j.core.async.ThreadNameCachingStrategy
         6: putstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.DEFAULT_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            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 30
            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=2, args_size=0
         0: .line 56
            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 0 /* name */
        start local 0 // java.lang.String name
         1: .line 58
            aload 0 /* name */
            ifnull 2
            aload 0 /* name */
            invokestatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.valueOf:(Ljava/lang/String;)Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            goto 3
      StackMap locals: java.lang.String
      StackMap stack:
         2: getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.DEFAULT_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
      StackMap locals:
      StackMap stack: org.apache.logging.log4j.core.async.ThreadNameCachingStrategy
         3: astore 1 /* result */
        start local 1 // org.apache.logging.log4j.core.async.ThreadNameCachingStrategy result
         4: .line 59
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
            ldc "AsyncLogger.ThreadNameStrategy={} (user specified {}, default is {})"
         5: .line 60
            aload 1 /* result */
            invokevirtual org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.name:()Ljava/lang/String;
            aload 0 /* name */
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.DEFAULT_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            invokevirtual org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.name:()Ljava/lang/String;
         6: .line 59
            invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
         7: .line 61
            aload 1 /* result */
         8: areturn
        end local 1 // org.apache.logging.log4j.core.async.ThreadNameCachingStrategy result
         9: .line 62
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* ex */
        start local 1 // java.lang.Exception ex
        10: .line 63
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
            ldc "Using AsyncLogger.ThreadNameStrategy.{}: '{}' not valid: {}"
        11: .line 64
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.DEFAULT_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            invokevirtual org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.name:()Ljava/lang/String;
            aload 0 /* name */
            aload 1 /* ex */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
        12: .line 63
            invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
        13: .line 65
            getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.DEFAULT_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
            areturn
        end local 1 // java.lang.Exception ex
        end local 0 // java.lang.String name
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            1   14     0    name  Ljava/lang/String;
            4    9     1  result  Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
           10   14     1      ex  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     8       9  Class java.lang.Exception

  static boolean isAllocatingThreadGetName();
    descriptor: ()Z
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=2, args_size=0
         0: .line 71
            getstatic org.apache.logging.log4j.util.Constants.JAVA_MAJOR_VERSION:I
            bipush 8
            if_icmpne 10
         1: .line 73
            ldc "(\\d+)\\.(\\d+)\\.(\\d+)_(\\d+)"
            invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
            astore 0 /* javaVersionPattern */
        start local 0 // java.util.regex.Pattern javaVersionPattern
         2: .line 74
            aload 0 /* javaVersionPattern */
            ldc "java.version"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
            astore 1 /* m */
        start local 1 // java.util.regex.Matcher m
         3: .line 75
            aload 1 /* m */
            invokevirtual java.util.regex.Matcher.matches:()Z
            ifeq 7
         4: .line 76
            aload 1 /* m */
            iconst_3
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            ifne 5
            aload 1 /* m */
            iconst_4
            invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            bipush 102
            if_icmpge 5
            iconst_1
            ireturn
      StackMap locals: java.util.regex.Pattern java.util.regex.Matcher
      StackMap stack:
         5: iconst_0
         6: ireturn
         7: .line 78
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 1 // java.util.regex.Matcher m
        end local 0 // java.util.regex.Pattern javaVersionPattern
         8: .line 79
      StackMap locals:
      StackMap stack: java.lang.Exception
            pop
         9: .line 80
            iconst_1
            ireturn
        10: .line 83
      StackMap locals:
      StackMap stack:
            getstatic org.apache.logging.log4j.util.Constants.JAVA_MAJOR_VERSION:I
            bipush 8
            if_icmpge 11
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
        11: iconst_0
            ireturn
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            2    8     0  javaVersionPattern  Ljava/util/regex/Pattern;
            3    8     1                   m  Ljava/util/regex/Matcher;
      Exception table:
        from    to  target  type
           1     6       8  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