public class org.apache.logging.log4j.core.util.internal.UnsafeUtil extends java.lang.Object
{
private static final org.apache.logging.log4j.Logger LOGGER;
private static java.lang.reflect.Method cleanerMethod;
private static java.lang.reflect.Method cleanMethod;
public void <init>()
{
org.apache.logging.log4j.core.util.internal.UnsafeUtil v;
v := @this: org.apache.logging.log4j.core.util.internal.UnsafeUtil;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static void clean(java.nio.ByteBuffer) throws java.lang.Exception
{
java.lang.Object[] v, v;
java.nio.ByteBuffer v;
java.lang.Object v;
java.lang.reflect.Method v, v, v, v;
boolean v;
v := @parameter: java.nio.ByteBuffer;
v = <org.apache.logging.log4j.core.util.internal.UnsafeUtil: java.lang.reflect.Method cleanerMethod>;
if v == null goto label;
v = <org.apache.logging.log4j.core.util.internal.UnsafeUtil: java.lang.reflect.Method cleanMethod>;
if v == null goto label;
v = virtualinvoke v.<java.nio.ByteBuffer: boolean isDirect()>();
if v == 0 goto label;
v = <org.apache.logging.log4j.core.util.internal.UnsafeUtil: java.lang.reflect.Method cleanMethod>;
v = <org.apache.logging.log4j.core.util.internal.UnsafeUtil: java.lang.reflect.Method cleanerMethod>;
v = newarray (java.lang.Object)[0];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = newarray (java.lang.Object)[0];
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
return;
}
static void <clinit>()
{
org.apache.logging.log4j.core.util.internal.UnsafeUtil$1 v;
java.security.PrivilegedActionException v;
org.apache.logging.log4j.Logger v;
org.apache.logging.log4j.status.StatusLogger v;
java.lang.Exception v;
boolean v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.util.internal.UnsafeUtil: org.apache.logging.log4j.Logger LOGGER> = v;
label:
v = new org.apache.logging.log4j.core.util.internal.UnsafeUtil$1;
specialinvoke v.<org.apache.logging.log4j.core.util.internal.UnsafeUtil$1: void <init>()>();
staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedExceptionAction)>(v);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.security.PrivilegedActionException: java.lang.Exception getException()>();
v = v instanceof java.lang.SecurityException;
if v == 0 goto label;
throw v;
label:
v = <org.apache.logging.log4j.core.util.internal.UnsafeUtil: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("sun.misc.Cleaner#clean() is not accessible. This will impact memory usage.", v);
<org.apache.logging.log4j.core.util.internal.UnsafeUtil: java.lang.reflect.Method cleanerMethod> = null;
<org.apache.logging.log4j.core.util.internal.UnsafeUtil: java.lang.reflect.Method cleanMethod> = null;
label:
return;
catch java.security.PrivilegedActionException from label to label with label;
}
public static sun.misc.Unsafe findUnsafe()
{
java.lang.Error v;
v = new java.lang.Error;
specialinvoke v.<java.lang.Error: void <init>(java.lang.String)>("Unresolved compilation error: Method <org.apache.logging.log4j.core.util.internal.UnsafeUtil: sun.misc.Unsafe findUnsafe()> does not exist!");
throw v;
}
}