public final class jdk.internal.logger.LazyLoggers
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: jdk.internal.logger.LazyLoggers
super_class: java.lang.Object
{
static final java.lang.RuntimePermission LOGGERFINDER_PERMISSION;
descriptor: Ljava/lang/RuntimePermission;
flags: (0x0018) ACC_STATIC, ACC_FINAL
private static volatile java.lang.System$LoggerFinder provider;
descriptor: Ljava/lang/System$LoggerFinder;
flags: (0x004a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE
private static final java.util.function.BiFunction<java.lang.String, java.lang.Module, java.lang.System$Logger> loggerSupplier;
descriptor: Ljava/util/function/BiFunction;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/util/function/BiFunction<Ljava/lang/String;Ljava/lang/Module;Ljava/lang/System$Logger;>;
private static final jdk.internal.logger.LazyLoggers$LazyLoggerFactories<java.lang.System$Logger> factories;
descriptor: Ljdk/internal/logger/LazyLoggers$LazyLoggerFactories;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljdk/internal/logger/LazyLoggers$LazyLoggerFactories<Ljava/lang/System$Logger;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=0, args_size=0
0: new java.lang.RuntimePermission
dup
ldc "loggerFinder"
invokespecial java.lang.RuntimePermission.<init>:(Ljava/lang/String;)V
1: putstatic jdk.internal.logger.LazyLoggers.LOGGERFINDER_PERMISSION:Ljava/lang/RuntimePermission;
2: new jdk.internal.logger.LazyLoggers$1
dup
invokespecial jdk.internal.logger.LazyLoggers$1.<init>:()V
3: putstatic jdk.internal.logger.LazyLoggers.loggerSupplier:Ljava/util/function/BiFunction;
4: new jdk.internal.logger.LazyLoggers$LazyLoggerFactories
dup
getstatic jdk.internal.logger.LazyLoggers.loggerSupplier:Ljava/util/function/BiFunction;
invokespecial jdk.internal.logger.LazyLoggers$LazyLoggerFactories.<init>:(Ljava/util/function/BiFunction;)V
5: putstatic jdk.internal.logger.LazyLoggers.factories:Ljdk/internal/logger/LazyLoggers$LazyLoggerFactories;
6: return
LocalVariableTable:
Start End Slot Name Signature
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: new java.lang.InternalError
dup
invokespecial java.lang.InternalError.<init>:()V
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljdk/internal/logger/LazyLoggers;
private static java.lang.System$LoggerFinder accessLoggerFinder();
descriptor: ()Ljava/lang/System$LoggerFinder;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=1, locals=2, args_size=0
0: getstatic jdk.internal.logger.LazyLoggers.provider:Ljava/lang/System$LoggerFinder;
astore 0
start local 0 1: aload 0
ifnonnull 8
2: invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
astore 1
start local 1 3: aload 1
ifnonnull 4
invokestatic java.lang.System$LoggerFinder.getLoggerFinder:()Ljava/lang/System$LoggerFinder;
goto 6
4: StackMap locals: java.lang.System$LoggerFinder java.lang.SecurityManager
StackMap stack:
invokedynamic run()Ljava/security/PrivilegedAction;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
()Ljava/lang/Object;
java/lang/System$LoggerFinder.getLoggerFinder()Ljava/lang/System$LoggerFinder; (6)
()Ljava/lang/System$LoggerFinder;
5: invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
checkcast java.lang.System$LoggerFinder
6: StackMap locals:
StackMap stack: java.lang.System$LoggerFinder
astore 0
7: aload 0
putstatic jdk.internal.logger.LazyLoggers.provider:Ljava/lang/System$LoggerFinder;
end local 1 8: StackMap locals:
StackMap stack:
aload 0
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
1 9 0 prov Ljava/lang/System$LoggerFinder;
3 8 1 sm Ljava/lang/SecurityManager;
static java.lang.System$Logger getLoggerFromFinder(java.lang.String, java.lang.Module);
descriptor: (Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
flags: (0x0008) ACC_STATIC
Code:
stack=6, locals=3, args_size=2
start local 0 start local 1 0: invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
astore 2
start local 2 1: aload 2
ifnonnull 3
2: invokestatic jdk.internal.logger.LazyLoggers.accessLoggerFinder:()Ljava/lang/System$LoggerFinder;
aload 0
aload 1
invokevirtual java.lang.System$LoggerFinder.getLogger:(Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
areturn
3: StackMap locals: java.lang.SecurityManager
StackMap stack:
aload 0
aload 1
invokedynamic run(Ljava/lang/String;Ljava/lang/Module;)Ljava/security/PrivilegedAction;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
()Ljava/lang/Object;
jdk/internal/logger/LazyLoggers.lambda$1(Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger; (6)
()Ljava/lang/System$Logger;
4: aconst_null
iconst_1
anewarray java.security.Permission
dup
iconst_0
getstatic jdk.internal.logger.LazyLoggers.LOGGERFINDER_PERMISSION:Ljava/lang/RuntimePermission;
aastore
5: invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;[Ljava/security/Permission;)Ljava/lang/Object;
checkcast java.lang.System$Logger
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 name Ljava/lang/String;
0 6 1 module Ljava/lang/Module;
1 6 2 sm Ljava/lang/SecurityManager;
MethodParameters:
Name Flags
name
module
public static final java.lang.System$Logger getLogger(java.lang.String, java.lang.Module);
descriptor: (Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokestatic jdk.internal.logger.DefaultLoggerFinder.isSystem:(Ljava/lang/Module;)Z
ifeq 2
1: aload 0
aload 1
invokestatic jdk.internal.logger.LazyLoggers.getLazyLogger:(Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
areturn
2: StackMap locals:
StackMap stack:
aload 0
aload 1
invokestatic jdk.internal.logger.LazyLoggers.getLoggerFromFinder:(Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 name Ljava/lang/String;
0 3 1 module Ljava/lang/Module;
MethodParameters:
Name Flags
name
module
public static final java.lang.System$Logger getLazyLogger(java.lang.String, java.lang.Module);
descriptor: (Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: invokestatic jdk.internal.logger.BootstrapLogger.useLazyLoggers:()Z
istore 2
start local 2 1: iload 2
ifeq 3
2: new jdk.internal.logger.LazyLoggers$JdkLazyLogger
dup
aload 0
aload 1
invokespecial jdk.internal.logger.LazyLoggers$JdkLazyLogger.<init>:(Ljava/lang/String;Ljava/lang/Module;)V
areturn
3: StackMap locals: int
StackMap stack:
aload 0
aload 1
invokestatic jdk.internal.logger.LazyLoggers.getLoggerFromFinder:(Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 name Ljava/lang/String;
0 4 1 module Ljava/lang/Module;
1 4 2 useLazyLogger Z
MethodParameters:
Name Flags
name
module
private static java.lang.System$Logger lambda$1(java.lang.String, java.lang.Module);
descriptor: (Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
Code:
stack=3, locals=2, args_size=2
0: invokestatic jdk.internal.logger.LazyLoggers.accessLoggerFinder:()Ljava/lang/System$LoggerFinder;
aload 0
aload 1
invokevirtual java.lang.System$LoggerFinder.getLogger:(Ljava/lang/String;Ljava/lang/Module;)Ljava/lang/System$Logger;
areturn
LocalVariableTable:
Start End Slot Name Signature
}
SourceFile: "LazyLoggers.java"
NestMembers:
jdk.internal.logger.LazyLoggers$1 jdk.internal.logger.LazyLoggers$JdkLazyLogger jdk.internal.logger.LazyLoggers$LazyLoggerAccessor jdk.internal.logger.LazyLoggers$LazyLoggerFactories jdk.internal.logger.LazyLoggers$LazyLoggerWrapper jdk.internal.logger.LazyLoggers$LoggerAccessor
InnerClasses:
public abstract Logger = java.lang.System$Logger of java.lang.System
public abstract LoggerFinder = java.lang.System$LoggerFinder of java.lang.System
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
jdk.internal.logger.LazyLoggers$1
private final JdkLazyLogger = jdk.internal.logger.LazyLoggers$JdkLazyLogger of jdk.internal.logger.LazyLoggers
final LazyLoggerAccessor = jdk.internal.logger.LazyLoggers$LazyLoggerAccessor of jdk.internal.logger.LazyLoggers
private final LazyLoggerFactories = jdk.internal.logger.LazyLoggers$LazyLoggerFactories of jdk.internal.logger.LazyLoggers
private LazyLoggerWrapper = jdk.internal.logger.LazyLoggers$LazyLoggerWrapper of jdk.internal.logger.LazyLoggers
abstract LoggerAccessor = jdk.internal.logger.LazyLoggers$LoggerAccessor of jdk.internal.logger.LazyLoggers