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: 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: 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: 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: 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: 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 0: aload 0
aload 1
iload 2
invokespecial java.lang.Enum.<init>:(Ljava/lang/String;I)V
return
end local 0 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: 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
start local 0 1: aload 0
ifnull 2
aload 0
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
start local 1 4: getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
ldc "AsyncLogger.ThreadNameStrategy={} (user specified {}, default is {})"
5: aload 1
invokevirtual org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.name:()Ljava/lang/String;
aload 0
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: invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
7: aload 1
8: areturn
end local 1 9: StackMap locals:
StackMap stack: java.lang.Exception
astore 1
start local 1 10: getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.LOGGER:Lorg/apache/logging/log4j/status/StatusLogger;
ldc "Using AsyncLogger.ThreadNameStrategy.{}: '{}' not valid: {}"
11: 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
aload 1
invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
12: invokevirtual org.apache.logging.log4j.status.StatusLogger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
13: getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.DEFAULT_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
areturn
end local 1 end local 0 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: getstatic org.apache.logging.log4j.util.Constants.JAVA_MAJOR_VERSION:I
bipush 8
if_icmpne 10
1: ldc "(\\d+)\\.(\\d+)\\.(\\d+)_(\\d+)"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
astore 0
start local 0 2: aload 0
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
start local 1 3: aload 1
invokevirtual java.util.regex.Matcher.matches:()Z
ifeq 7
4: aload 1
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
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: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 1 end local 0 8: StackMap locals:
StackMap stack: java.lang.Exception
pop
9: iconst_1
ireturn
10: 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: 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: 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