public class org.apache.logging.log4j.core.impl.ReusableLogEventFactory implements org.apache.logging.log4j.core.impl.LogEventFactory
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.logging.log4j.core.impl.ReusableLogEventFactory
super_class: java.lang.Object
{
private static final org.apache.logging.log4j.core.async.ThreadNameCachingStrategy THREAD_NAME_CACHING_STRATEGY;
descriptor: Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final org.apache.logging.log4j.core.util.Clock CLOCK;
descriptor: Lorg/apache/logging/log4j/core/util/Clock;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static java.lang.ThreadLocal<org.apache.logging.log4j.core.impl.MutableLogEvent> mutableLogEventThreadLocal;
descriptor: Ljava/lang/ThreadLocal;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Signature: Ljava/lang/ThreadLocal<Lorg/apache/logging/log4j/core/impl/MutableLogEvent;>;
private final org.apache.logging.log4j.core.ContextDataInjector injector;
descriptor: Lorg/apache/logging/log4j/core/ContextDataInjector;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: invokestatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.create:()Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
putstatic org.apache.logging.log4j.core.impl.ReusableLogEventFactory.THREAD_NAME_CACHING_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
1: invokestatic org.apache.logging.log4j.core.util.ClockFactory.getClock:()Lorg/apache/logging/log4j/core/util/Clock;
putstatic org.apache.logging.log4j.core.impl.ReusableLogEventFactory.CLOCK:Lorg/apache/logging/log4j/core/util/Clock;
2: new java.lang.ThreadLocal
dup
invokespecial java.lang.ThreadLocal.<init>:()V
putstatic org.apache.logging.log4j.core.impl.ReusableLogEventFactory.mutableLogEventThreadLocal:Ljava/lang/ThreadLocal;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
invokestatic org.apache.logging.log4j.core.impl.ContextDataInjectorFactory.createInjector:()Lorg/apache/logging/log4j/core/ContextDataInjector;
putfield org.apache.logging.log4j.core.impl.ReusableLogEventFactory.injector:Lorg/apache/logging/log4j/core/ContextDataInjector;
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/logging/log4j/core/impl/ReusableLogEventFactory;
public org.apache.logging.log4j.core.LogEvent createEvent(java.lang.String, org.apache.logging.log4j.Marker, java.lang.String, org.apache.logging.log4j.Level, org.apache.logging.log4j.message.Message, java.util.List<org.apache.logging.log4j.core.config.Property>, java.lang.Throwable);
descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/Marker;Ljava/lang/String;Lorg/apache/logging/log4j/Level;Lorg/apache/logging/log4j/message/Message;Ljava/util/List;Ljava/lang/Throwable;)Lorg/apache/logging/log4j/core/LogEvent;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=10, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: getstatic org.apache.logging.log4j.core.impl.ReusableLogEventFactory.mutableLogEventThreadLocal:Ljava/lang/ThreadLocal;
invokevirtual java.lang.ThreadLocal.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.impl.MutableLogEvent
astore 8
start local 8 1: aload 8
ifnull 2
aload 8
getfield org.apache.logging.log4j.core.impl.MutableLogEvent.reserved:Z
ifeq 11
2: StackMap locals: org.apache.logging.log4j.core.impl.MutableLogEvent
StackMap stack:
aload 8
ifnonnull 3
iconst_1
goto 4
StackMap locals:
StackMap stack:
3: iconst_0
StackMap locals:
StackMap stack: int
4: istore 9
start local 9 5: new org.apache.logging.log4j.core.impl.MutableLogEvent
dup
invokespecial org.apache.logging.log4j.core.impl.MutableLogEvent.<init>:()V
astore 8
6: aload 8
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.getId:()J
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setThreadId:(J)V
7: aload 8
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setThreadName:(Ljava/lang/String;)V
8: aload 8
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.getPriority:()I
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setThreadPriority:(I)V
9: iload 9
ifeq 11
10: getstatic org.apache.logging.log4j.core.impl.ReusableLogEventFactory.mutableLogEventThreadLocal:Ljava/lang/ThreadLocal;
aload 8
invokevirtual java.lang.ThreadLocal.set:(Ljava/lang/Object;)V
end local 9 11: StackMap locals:
StackMap stack:
aload 8
iconst_1
putfield org.apache.logging.log4j.core.impl.MutableLogEvent.reserved:Z
12: aload 8
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.clear:()V
13: aload 8
aload 1
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setLoggerName:(Ljava/lang/String;)V
14: aload 8
aload 2
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setMarker:(Lorg/apache/logging/log4j/Marker;)V
15: aload 8
aload 3
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setLoggerFqcn:(Ljava/lang/String;)V
16: aload 8
aload 4
ifnonnull 17
getstatic org.apache.logging.log4j.Level.OFF:Lorg/apache/logging/log4j/Level;
goto 18
StackMap locals:
StackMap stack: org.apache.logging.log4j.core.impl.MutableLogEvent
17: aload 4
StackMap locals: org.apache.logging.log4j.core.impl.ReusableLogEventFactory java.lang.String org.apache.logging.log4j.Marker java.lang.String org.apache.logging.log4j.Level org.apache.logging.log4j.message.Message java.util.List java.lang.Throwable org.apache.logging.log4j.core.impl.MutableLogEvent
StackMap stack: org.apache.logging.log4j.core.impl.MutableLogEvent org.apache.logging.log4j.Level
18: invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setLevel:(Lorg/apache/logging/log4j/Level;)V
19: aload 8
aload 5
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setMessage:(Lorg/apache/logging/log4j/message/Message;)V
20: aload 8
getstatic org.apache.logging.log4j.core.impl.ReusableLogEventFactory.CLOCK:Lorg/apache/logging/log4j/core/util/Clock;
invokestatic org.apache.logging.log4j.core.impl.Log4jLogEvent.getNanoClock:()Lorg/apache/logging/log4j/core/util/NanoClock;
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.initTime:(Lorg/apache/logging/log4j/core/util/Clock;Lorg/apache/logging/log4j/core/util/NanoClock;)V
21: aload 8
aload 7
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setThrown:(Ljava/lang/Throwable;)V
22: aload 8
aload 0
getfield org.apache.logging.log4j.core.impl.ReusableLogEventFactory.injector:Lorg/apache/logging/log4j/core/ContextDataInjector;
aload 6
aload 8
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.getContextData:()Lorg/apache/logging/log4j/util/ReadOnlyStringMap;
checkcast org.apache.logging.log4j.util.StringMap
invokeinterface org.apache.logging.log4j.core.ContextDataInjector.injectContextData:(Ljava/util/List;Lorg/apache/logging/log4j/util/StringMap;)Lorg/apache/logging/log4j/util/StringMap;
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setContextData:(Lorg/apache/logging/log4j/util/StringMap;)V
23: aload 8
invokestatic org.apache.logging.log4j.ThreadContext.getDepth:()I
ifne 24
getstatic org.apache.logging.log4j.ThreadContext.EMPTY_STACK:Lorg/apache/logging/log4j/spi/ThreadContextStack;
goto 25
StackMap locals:
StackMap stack: org.apache.logging.log4j.core.impl.MutableLogEvent
24: invokestatic org.apache.logging.log4j.ThreadContext.cloneStack:()Lorg/apache/logging/log4j/ThreadContext$ContextStack;
StackMap locals: org.apache.logging.log4j.core.impl.ReusableLogEventFactory java.lang.String org.apache.logging.log4j.Marker java.lang.String org.apache.logging.log4j.Level org.apache.logging.log4j.message.Message java.util.List java.lang.Throwable org.apache.logging.log4j.core.impl.MutableLogEvent
StackMap stack: org.apache.logging.log4j.core.impl.MutableLogEvent org.apache.logging.log4j.ThreadContext$ContextStack
25: invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setContextStack:(Lorg/apache/logging/log4j/ThreadContext$ContextStack;)V
26: getstatic org.apache.logging.log4j.core.impl.ReusableLogEventFactory.THREAD_NAME_CACHING_STRATEGY:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
getstatic org.apache.logging.log4j.core.async.ThreadNameCachingStrategy.UNCACHED:Lorg/apache/logging/log4j/core/async/ThreadNameCachingStrategy;
if_acmpne 29
27: aload 8
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.getName:()Ljava/lang/String;
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setThreadName:(Ljava/lang/String;)V
28: aload 8
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.getPriority:()I
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.setThreadPriority:(I)V
29: StackMap locals:
StackMap stack:
aload 8
areturn
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 30 0 this Lorg/apache/logging/log4j/core/impl/ReusableLogEventFactory;
0 30 1 loggerName Ljava/lang/String;
0 30 2 marker Lorg/apache/logging/log4j/Marker;
0 30 3 fqcn Ljava/lang/String;
0 30 4 level Lorg/apache/logging/log4j/Level;
0 30 5 message Lorg/apache/logging/log4j/message/Message;
0 30 6 properties Ljava/util/List<Lorg/apache/logging/log4j/core/config/Property;>;
0 30 7 t Ljava/lang/Throwable;
1 30 8 result Lorg/apache/logging/log4j/core/impl/MutableLogEvent;
5 11 9 initThreadLocal Z
Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/Marker;Ljava/lang/String;Lorg/apache/logging/log4j/Level;Lorg/apache/logging/log4j/message/Message;Ljava/util/List<Lorg/apache/logging/log4j/core/config/Property;>;Ljava/lang/Throwable;)Lorg/apache/logging/log4j/core/LogEvent;
MethodParameters:
Name Flags
loggerName final
marker final
fqcn final
level final
message final
properties final
t final
public static void release(org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
instanceof org.apache.logging.log4j.core.impl.MutableLogEvent
ifeq 4
1: aload 0
checkcast org.apache.logging.log4j.core.impl.MutableLogEvent
astore 1
start local 1 2: aload 1
invokevirtual org.apache.logging.log4j.core.impl.MutableLogEvent.clear:()V
3: aload 1
iconst_0
putfield org.apache.logging.log4j.core.impl.MutableLogEvent.reserved:Z
end local 1 4: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 logEvent Lorg/apache/logging/log4j/core/LogEvent;
2 4 1 mutableLogEvent Lorg/apache/logging/log4j/core/impl/MutableLogEvent;
MethodParameters:
Name Flags
logEvent final
}
SourceFile: "ReusableLogEventFactory.java"
InnerClasses:
public abstract ContextStack = org.apache.logging.log4j.ThreadContext$ContextStack of org.apache.logging.log4j.ThreadContext