class com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable implements java.lang.Runnable
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable
super_class: java.lang.Object
{
private final java.lang.Runnable task;
descriptor: Ljava/lang/Runnable;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final com.codahale.metrics.Timer$Context idleContext;
descriptor: Lcom/codahale/metrics/Timer$Context;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
final com.codahale.metrics.InstrumentedExecutorService this$0;
descriptor: Lcom/codahale/metrics/InstrumentedExecutorService;
flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC
void <init>(com.codahale.metrics.InstrumentedExecutorService, java.lang.Runnable);
descriptor: (Lcom/codahale/metrics/InstrumentedExecutorService;Ljava/lang/Runnable;)V
flags: (0x0000)
Code:
stack=2, locals=3, args_size=3
start local 0 // com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable this
start local 2 // java.lang.Runnable task
0: .line 170
aload 0 /* this */
aload 1
putfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.this$0:Lcom/codahale/metrics/InstrumentedExecutorService;
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 171
aload 0 /* this */
aload 2 /* task */
putfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.task:Ljava/lang/Runnable;
2: .line 172
aload 0 /* this */
aload 1
getfield com.codahale.metrics.InstrumentedExecutorService.idle:Lcom/codahale/metrics/Timer;
invokevirtual com.codahale.metrics.Timer.time:()Lcom/codahale/metrics/Timer$Context;
putfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.idleContext:Lcom/codahale/metrics/Timer$Context;
3: .line 173
return
end local 2 // java.lang.Runnable task
end local 0 // com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable this
LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lcom/codahale/metrics/InstrumentedExecutorService$InstrumentedRunnable;
0 4 2 task Ljava/lang/Runnable;
MethodParameters:
Name Flags
this$0 final
task
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=5, args_size=1
start local 0 // com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable this
0: .line 177
aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.idleContext:Lcom/codahale/metrics/Timer$Context;
invokevirtual com.codahale.metrics.Timer$Context.stop:()J
pop2
1: .line 178
aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.this$0:Lcom/codahale/metrics/InstrumentedExecutorService;
getfield com.codahale.metrics.InstrumentedExecutorService.running:Lcom/codahale/metrics/Counter;
invokevirtual com.codahale.metrics.Counter.inc:()V
2: .line 179
aconst_null
astore 1
aconst_null
astore 2
3: aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.this$0:Lcom/codahale/metrics/InstrumentedExecutorService;
getfield com.codahale.metrics.InstrumentedExecutorService.duration:Lcom/codahale/metrics/Timer;
invokevirtual com.codahale.metrics.Timer.time:()Lcom/codahale/metrics/Timer$Context;
astore 3 /* durationContext */
start local 3 // com.codahale.metrics.Timer$Context durationContext
4: .line 180
aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.task:Ljava/lang/Runnable;
invokeinterface java.lang.Runnable.run:()V
5: .line 181
aload 3 /* durationContext */
ifnull 15
aload 3 /* durationContext */
invokevirtual com.codahale.metrics.Timer$Context.close:()V
goto 15
StackMap locals: com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable java.lang.Throwable java.lang.Throwable com.codahale.metrics.Timer$Context
StackMap stack: java.lang.Throwable
6: astore 1
aload 3 /* durationContext */
ifnull 7
aload 3 /* durationContext */
invokevirtual com.codahale.metrics.Timer$Context.close:()V
end local 3 // com.codahale.metrics.Timer$Context durationContext
StackMap locals:
StackMap stack:
7: aload 1
athrow
StackMap locals:
StackMap stack: java.lang.Throwable
8: astore 2
aload 1
ifnonnull 9
aload 2
astore 1
goto 10
StackMap locals:
StackMap stack:
9: aload 1
aload 2
if_acmpeq 10
aload 1
aload 2
invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
StackMap locals:
StackMap stack:
10: aload 1
athrow
StackMap locals: com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable
StackMap stack: java.lang.Throwable
11: astore 4
12: .line 182
aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.this$0:Lcom/codahale/metrics/InstrumentedExecutorService;
getfield com.codahale.metrics.InstrumentedExecutorService.running:Lcom/codahale/metrics/Counter;
invokevirtual com.codahale.metrics.Counter.dec:()V
13: .line 183
aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.this$0:Lcom/codahale/metrics/InstrumentedExecutorService;
getfield com.codahale.metrics.InstrumentedExecutorService.completed:Lcom/codahale/metrics/Meter;
invokevirtual com.codahale.metrics.Meter.mark:()V
14: .line 184
aload 4
athrow
15: .line 182
StackMap locals:
StackMap stack:
aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.this$0:Lcom/codahale/metrics/InstrumentedExecutorService;
getfield com.codahale.metrics.InstrumentedExecutorService.running:Lcom/codahale/metrics/Counter;
invokevirtual com.codahale.metrics.Counter.dec:()V
16: .line 183
aload 0 /* this */
getfield com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable.this$0:Lcom/codahale/metrics/InstrumentedExecutorService;
getfield com.codahale.metrics.InstrumentedExecutorService.completed:Lcom/codahale/metrics/Meter;
invokevirtual com.codahale.metrics.Meter.mark:()V
17: .line 185
return
end local 0 // com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable this
LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lcom/codahale/metrics/InstrumentedExecutorService$InstrumentedRunnable;
4 7 3 durationContext Lcom/codahale/metrics/Timer$Context;
Exception table:
from to target type
4 5 6 any
3 8 8 any
2 11 11 any
}
SourceFile: "InstrumentedExecutorService.java"
NestHost: com.codahale.metrics.InstrumentedExecutorService
InnerClasses:
private InstrumentedRunnable = com.codahale.metrics.InstrumentedExecutorService$InstrumentedRunnable of com.codahale.metrics.InstrumentedExecutorService
public Context = com.codahale.metrics.Timer$Context of com.codahale.metrics.Timer