final class io.netty.util.HashedWheelTimer$HashedWheelTimeout implements io.netty.util.Timeout
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: io.netty.util.HashedWheelTimer$HashedWheelTimeout
super_class: java.lang.Object
{
private static final int ST_INIT;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 0
private static final int ST_CANCELLED;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 1
private static final int ST_EXPIRED;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 2
private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<io.netty.util.HashedWheelTimer$HashedWheelTimeout> STATE_UPDATER;
descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;>;
private final io.netty.util.HashedWheelTimer timer;
descriptor: Lio/netty/util/HashedWheelTimer;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final io.netty.util.TimerTask task;
descriptor: Lio/netty/util/TimerTask;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final long deadline;
descriptor: J
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private volatile int state;
descriptor: I
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
long remainingRounds;
descriptor: J
flags: (0x0000)
io.netty.util.HashedWheelTimer$HashedWheelTimeout next;
descriptor: Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
flags: (0x0000)
io.netty.util.HashedWheelTimer$HashedWheelTimeout prev;
descriptor: Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
flags: (0x0000)
io.netty.util.HashedWheelTimer$HashedWheelBucket bucket;
descriptor: Lio/netty/util/HashedWheelTimer$HashedWheelBucket;
flags: (0x0000)
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: ldc Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
ldc "state"
invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
1: putstatic io.netty.util.HashedWheelTimer$HashedWheelTimeout.STATE_UPDATER:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
2: return
LocalVariableTable:
Start End Slot Name Signature
void <init>(io.netty.util.HashedWheelTimer, io.netty.util.TimerTask, long);
descriptor: (Lio/netty/util/HashedWheelTimer;Lio/netty/util/TimerTask;J)V
flags: (0x0000)
Code:
stack=3, locals=5, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.state:I
2: aload 0
aload 1
putfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.timer:Lio/netty/util/HashedWheelTimer;
3: aload 0
aload 2
putfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.task:Lio/netty/util/TimerTask;
4: aload 0
lload 3
putfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.deadline:J
5: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
0 6 1 timer Lio/netty/util/HashedWheelTimer;
0 6 2 task Lio/netty/util/TimerTask;
0 6 3 deadline J
MethodParameters:
Name Flags
timer
task
deadline
public io.netty.util.Timer timer();
descriptor: ()Lio/netty/util/Timer;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.timer:Lio/netty/util/HashedWheelTimer;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
public io.netty.util.TimerTask task();
descriptor: ()Lio/netty/util/TimerTask;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.task:Lio/netty/util/TimerTask;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
public boolean cancel();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
iconst_0
iconst_1
invokevirtual io.netty.util.HashedWheelTimer$HashedWheelTimeout.compareAndSetState:(II)Z
ifne 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.timer:Lio/netty/util/HashedWheelTimer;
getfield io.netty.util.HashedWheelTimer.cancelledTimeouts:Ljava/util/Queue;
aload 0
invokeinterface java.util.Queue.add:(Ljava/lang/Object;)Z
pop
3: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
void remove();
descriptor: ()V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.bucket:Lio/netty/util/HashedWheelTimer$HashedWheelBucket;
astore 1
start local 1 1: aload 1
ifnull 4
2: aload 1
aload 0
invokevirtual io.netty.util.HashedWheelTimer$HashedWheelBucket.remove:(Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;)Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
pop
3: goto 5
4: StackMap locals: io.netty.util.HashedWheelTimer$HashedWheelBucket
StackMap stack:
aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.timer:Lio/netty/util/HashedWheelTimer;
getfield io.netty.util.HashedWheelTimer.pendingTimeouts:Ljava/util/concurrent/atomic/AtomicLong;
invokevirtual java.util.concurrent.atomic.AtomicLong.decrementAndGet:()J
pop2
5: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
1 6 1 bucket Lio/netty/util/HashedWheelTimer$HashedWheelBucket;
public boolean compareAndSetState(int, int);
descriptor: (II)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: getstatic io.netty.util.HashedWheelTimer$HashedWheelTimeout.STATE_UPDATER:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
aload 0
iload 1
iload 2
invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.compareAndSet:(Ljava/lang/Object;II)Z
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
0 1 1 expected I
0 1 2 state I
MethodParameters:
Name Flags
expected
state
public int state();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.state:I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
public boolean isCancelled();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual io.netty.util.HashedWheelTimer$HashedWheelTimeout.state:()I
iconst_1
if_icmpne 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
public boolean isExpired();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual io.netty.util.HashedWheelTimer$HashedWheelTimeout.state:()I
iconst_2
if_icmpne 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
public void expire();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=1
start local 0 0: aload 0
iconst_0
iconst_2
invokevirtual io.netty.util.HashedWheelTimer$HashedWheelTimeout.compareAndSetState:(II)Z
ifne 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.task:Lio/netty/util/TimerTask;
aload 0
invokeinterface io.netty.util.TimerTask.run:(Lio/netty/util/Timeout;)V
3: goto 7
StackMap locals:
StackMap stack: java.lang.Throwable
4: astore 1
start local 1 5: getstatic io.netty.util.HashedWheelTimer.logger:Lio/netty/util/internal/logging/InternalLogger;
invokeinterface io.netty.util.internal.logging.InternalLogger.isWarnEnabled:()Z
ifeq 7
6: getstatic io.netty.util.HashedWheelTimer.logger:Lio/netty/util/internal/logging/InternalLogger;
new java.lang.StringBuilder
dup
ldc "An exception was thrown by "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc Lio/netty/util/TimerTask;
invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
bipush 46
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 1
invokeinterface io.netty.util.internal.logging.InternalLogger.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 1 7: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
5 7 1 t Ljava/lang/Throwable;
Exception table:
from to target type
2 3 4 Class java.lang.Throwable
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=6, args_size=1
start local 0 0: invokestatic java.lang.System.nanoTime:()J
lstore 1
start local 1 1: aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.deadline:J
lload 1
lsub
aload 0
getfield io.netty.util.HashedWheelTimer$HashedWheelTimeout.timer:Lio/netty/util/HashedWheelTimer;
getfield io.netty.util.HashedWheelTimer.startTime:J
ladd
lstore 3
start local 3 2: new java.lang.StringBuilder
dup
sipush 192
invokespecial java.lang.StringBuilder.<init>:(I)V
3: aload 0
invokestatic io.netty.util.internal.StringUtil.simpleClassName:(Ljava/lang/Object;)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
4: bipush 40
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
5: ldc "deadline: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
6: astore 5
start local 5 7: lload 3
lconst_0
lcmp
ifle 11
8: aload 5
lload 3
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
9: ldc " ns later"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
10: goto 16
StackMap locals: long long java.lang.StringBuilder
StackMap stack:
11: lload 3
lconst_0
lcmp
ifge 15
12: aload 5
lload 3
lneg
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
13: ldc " ns ago"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
14: goto 16
15: StackMap locals:
StackMap stack:
aload 5
ldc "now"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
16: StackMap locals:
StackMap stack:
aload 0
invokevirtual io.netty.util.HashedWheelTimer$HashedWheelTimeout.isCancelled:()Z
ifeq 18
17: aload 5
ldc ", cancelled"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
18: StackMap locals:
StackMap stack:
aload 5
ldc ", task: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
19: aload 0
invokevirtual io.netty.util.HashedWheelTimer$HashedWheelTimeout.task:()Lio/netty/util/TimerTask;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
20: bipush 41
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
21: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
22: areturn
end local 5 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 23 0 this Lio/netty/util/HashedWheelTimer$HashedWheelTimeout;
1 23 1 currentTime J
2 23 3 remaining J
7 23 5 buf Ljava/lang/StringBuilder;
}
SourceFile: "HashedWheelTimer.java"
NestHost: io.netty.util.HashedWheelTimer
InnerClasses:
private final HashedWheelBucket = io.netty.util.HashedWheelTimer$HashedWheelBucket of io.netty.util.HashedWheelTimer
private final HashedWheelTimeout = io.netty.util.HashedWheelTimer$HashedWheelTimeout of io.netty.util.HashedWheelTimer