final class org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout extends java.lang.Object implements org.apache.dubbo.common.timer.Timeout
{
private static final int ST_INIT;
private static final int ST_CANCELLED;
private static final int ST_EXPIRED;
private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater STATE_UPDATER;
private final org.apache.dubbo.common.timer.HashedWheelTimer timer;
private final org.apache.dubbo.common.timer.TimerTask task;
private final long deadline;
private volatile int state;
long remainingRounds;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout next;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout prev;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelBucket bucket;
void <init>(org.apache.dubbo.common.timer.HashedWheelTimer, org.apache.dubbo.common.timer.TimerTask, long)
{
long v;
org.apache.dubbo.common.timer.HashedWheelTimer v;
org.apache.dubbo.common.timer.TimerTask v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v := @parameter: org.apache.dubbo.common.timer.HashedWheelTimer;
v := @parameter: org.apache.dubbo.common.timer.TimerTask;
v := @parameter: long;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: int state> = 0;
v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.HashedWheelTimer timer> = v;
v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.TimerTask task> = v;
v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: long deadline> = v;
return;
}
public org.apache.dubbo.common.timer.Timer timer()
{
org.apache.dubbo.common.timer.HashedWheelTimer v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.HashedWheelTimer timer>;
return v;
}
public org.apache.dubbo.common.timer.TimerTask task()
{
org.apache.dubbo.common.timer.TimerTask v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.TimerTask task>;
return v;
}
public boolean cancel()
{
java.util.Queue v;
org.apache.dubbo.common.timer.HashedWheelTimer v;
boolean v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = virtualinvoke v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: boolean compareAndSetState(int,int)>(0, 1);
if v != 0 goto label;
return 0;
label:
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.HashedWheelTimer timer>;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer: java.util.Queue cancelledTimeouts>;
interfaceinvoke v.<java.util.Queue: boolean add(java.lang.Object)>(v);
return 1;
}
void remove()
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelBucket v;
org.apache.dubbo.common.timer.HashedWheelTimer v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelBucket bucket>;
if v == null goto label;
virtualinvoke v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelBucket: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout remove(org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout)>(v);
goto label;
label:
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.HashedWheelTimer timer>;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer: java.util.concurrent.atomic.AtomicLong pendingTimeouts>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long decrementAndGet()>();
label:
return;
}
public boolean compareAndSetState(int, int)
{
java.util.concurrent.atomic.AtomicIntegerFieldUpdater v;
int v, v;
boolean v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v := @parameter: int;
v := @parameter: int;
v = <org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: java.util.concurrent.atomic.AtomicIntegerFieldUpdater STATE_UPDATER>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicIntegerFieldUpdater: boolean compareAndSet(java.lang.Object,int,int)>(v, v, v);
return v;
}
public int state()
{
int v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: int state>;
return v;
}
public boolean isCancelled()
{
int v;
boolean v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = virtualinvoke v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: int state()>();
if v != 1 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean isExpired()
{
int v;
boolean v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = virtualinvoke v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: int state()>();
if v != 2 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void expire()
{
java.lang.Throwable v;
org.apache.dubbo.common.logger.Logger v, v;
org.apache.dubbo.common.timer.TimerTask v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
java.lang.Class v;
java.lang.String v, v;
boolean v, v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = virtualinvoke v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: boolean compareAndSetState(int,int)>(0, 2);
if v != 0 goto label;
return;
label:
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.TimerTask task>;
interfaceinvoke v.<org.apache.dubbo.common.timer.TimerTask: void run(org.apache.dubbo.common.timer.Timeout)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.common.timer.HashedWheelTimer: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isWarnEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.common.timer.HashedWheelTimer: org.apache.dubbo.common.logger.Logger logger>;
v = class "Lorg/apache/dubbo/common/timer/TimerTask;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("An exception was thrown by \u.");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
public java.lang.String toString()
{
long v, v, v, v, v, v;
org.apache.dubbo.common.timer.TimerTask v;
org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout v;
byte v, v;
java.lang.String v, v;
boolean v;
org.apache.dubbo.common.timer.HashedWheelTimer v;
java.lang.Class v;
java.lang.StringBuilder v, v, v, v;
v := @this: org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout;
v = staticinvoke <java.lang.System: long nanoTime()>();
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: long deadline>;
v = v - v;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.HashedWheelTimer timer>;
v = v.<org.apache.dubbo.common.timer.HashedWheelTimer: long startTime>;
v = v + v;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <org.apache.dubbo.common.utils.ClassUtils: java.lang.String simpleClassName(java.lang.Class)>(v);
specialinvoke v.<java.lang.StringBuilder: void <init>(int)>(192);
v = v cmp 0L;
if v <= 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ns later");
goto label;
label:
v = v cmp 0L;
if v >= 0 goto label;
v = neg v;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(" ns ago");
goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("now");
label:
v = virtualinvoke v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: boolean isCancelled()>();
if v == 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", cancelled");
label:
v = virtualinvoke v.<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: org.apache.dubbo.common.timer.TimerTask task()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,long,long,org.apache.dubbo.common.timer.TimerTask)>(v, v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001(deadline: \u0001\u, task: \u)");
return v;
}
static void <clinit>()
{
java.util.concurrent.atomic.AtomicIntegerFieldUpdater v;
v = staticinvoke <java.util.concurrent.atomic.AtomicIntegerFieldUpdater: java.util.concurrent.atomic.AtomicIntegerFieldUpdater newUpdater(java.lang.Class,java.lang.String)>(class "Lorg/apache/dubbo/common/timer/HashedWheelTimer$HashedWheelTimeout;", "state");
<org.apache.dubbo.common.timer.HashedWheelTimer$HashedWheelTimeout: java.util.concurrent.atomic.AtomicIntegerFieldUpdater STATE_UPDATER> = v;
return;
}
}