public class org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor extends org.springframework.scheduling.concurrent.ExecutorConfigurationSupport implements org.springframework.core.task.AsyncListenableTaskExecutor, org.springframework.scheduling.SchedulingTaskExecutor
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor
super_class: org.springframework.scheduling.concurrent.ExecutorConfigurationSupport
{
private final java.lang.Object poolSizeMonitor;
descriptor: Ljava/lang/Object;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private int corePoolSize;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private int maxPoolSize;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private int keepAliveSeconds;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private int queueCapacity;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private boolean allowCoreThreadTimeOut;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private org.springframework.core.task.TaskDecorator taskDecorator;
descriptor: Lorg/springframework/core/task/TaskDecorator;
flags: (0x0002) ACC_PRIVATE
RuntimeVisibleAnnotations:
org.springframework.lang.Nullable()
private java.util.concurrent.ThreadPoolExecutor threadPoolExecutor;
descriptor: Ljava/util/concurrent/ThreadPoolExecutor;
flags: (0x0002) ACC_PRIVATE
RuntimeVisibleAnnotations:
org.springframework.lang.Nullable()
private final java.util.Map<java.lang.Runnable, java.lang.Object> decoratedTaskMap;
descriptor: Ljava/util/Map;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Map<Ljava/lang/Runnable;Ljava/lang/Object;>;
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=1, args_size=1
start local 0 0: aload 0
invokespecial org.springframework.scheduling.concurrent.ExecutorConfigurationSupport.<init>:()V
1: aload 0
new java.lang.Object
dup
invokespecial java.lang.Object.<init>:()V
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.poolSizeMonitor:Ljava/lang/Object;
2: aload 0
iconst_1
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.corePoolSize:I
3: aload 0
ldc 2147483647
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.maxPoolSize:I
4: aload 0
bipush 60
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.keepAliveSeconds:I
5: aload 0
ldc 2147483647
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.queueCapacity:I
6: aload 0
iconst_0
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.allowCoreThreadTimeOut:Z
7: aload 0
8: new org.springframework.util.ConcurrentReferenceHashMap
dup
bipush 16
getstatic org.springframework.util.ConcurrentReferenceHashMap$ReferenceType.WEAK:Lorg/springframework/util/ConcurrentReferenceHashMap$ReferenceType;
invokespecial org.springframework.util.ConcurrentReferenceHashMap.<init>:(ILorg/springframework/util/ConcurrentReferenceHashMap$ReferenceType;)V
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.decoratedTaskMap:Ljava/util/Map;
9: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
public void setCorePoolSize(int);
descriptor: (I)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.poolSizeMonitor:Ljava/lang/Object;
dup
astore 2
monitorenter
1: aload 0
iload 1
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.corePoolSize:I
2: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
ifnull 4
3: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
iload 1
invokevirtual java.util.concurrent.ThreadPoolExecutor.setCorePoolSize:(I)V
4: StackMap locals: java.lang.Object
StackMap stack:
aload 2
monitorexit
5: goto 8
StackMap locals:
StackMap stack: java.lang.Throwable
6: aload 2
monitorexit
7: athrow
8: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 9 1 corePoolSize I
Exception table:
from to target type
1 5 6 any
6 7 6 any
MethodParameters:
Name Flags
corePoolSize
public int getCorePoolSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.poolSizeMonitor:Ljava/lang/Object;
dup
astore 1
monitorenter
1: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.corePoolSize:I
aload 1
monitorexit
2: ireturn
3: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.lang.Object
StackMap stack: java.lang.Throwable
aload 1
monitorexit
4: athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
Exception table:
from to target type
1 2 3 any
3 4 3 any
public void setMaxPoolSize(int);
descriptor: (I)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.poolSizeMonitor:Ljava/lang/Object;
dup
astore 2
monitorenter
1: aload 0
iload 1
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.maxPoolSize:I
2: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
ifnull 4
3: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
iload 1
invokevirtual java.util.concurrent.ThreadPoolExecutor.setMaximumPoolSize:(I)V
4: StackMap locals: java.lang.Object
StackMap stack:
aload 2
monitorexit
5: goto 8
StackMap locals:
StackMap stack: java.lang.Throwable
6: aload 2
monitorexit
7: athrow
8: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 9 1 maxPoolSize I
Exception table:
from to target type
1 5 6 any
6 7 6 any
MethodParameters:
Name Flags
maxPoolSize
public int getMaxPoolSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.poolSizeMonitor:Ljava/lang/Object;
dup
astore 1
monitorenter
1: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.maxPoolSize:I
aload 1
monitorexit
2: ireturn
3: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.lang.Object
StackMap stack: java.lang.Throwable
aload 1
monitorexit
4: athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
Exception table:
from to target type
1 2 3 any
3 4 3 any
public void setKeepAliveSeconds(int);
descriptor: (I)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.poolSizeMonitor:Ljava/lang/Object;
dup
astore 2
monitorenter
1: aload 0
iload 1
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.keepAliveSeconds:I
2: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
ifnull 4
3: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
iload 1
i2l
getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
invokevirtual java.util.concurrent.ThreadPoolExecutor.setKeepAliveTime:(JLjava/util/concurrent/TimeUnit;)V
4: StackMap locals: java.lang.Object
StackMap stack:
aload 2
monitorexit
5: goto 8
StackMap locals:
StackMap stack: java.lang.Throwable
6: aload 2
monitorexit
7: athrow
8: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 9 1 keepAliveSeconds I
Exception table:
from to target type
1 5 6 any
6 7 6 any
MethodParameters:
Name Flags
keepAliveSeconds
public int getKeepAliveSeconds();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.poolSizeMonitor:Ljava/lang/Object;
dup
astore 1
monitorenter
1: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.keepAliveSeconds:I
aload 1
monitorexit
2: ireturn
3: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.lang.Object
StackMap stack: java.lang.Throwable
aload 1
monitorexit
4: athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
Exception table:
from to target type
1 2 3 any
3 4 3 any
public void setQueueCapacity(int);
descriptor: (I)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.queueCapacity:I
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 2 1 queueCapacity I
MethodParameters:
Name Flags
queueCapacity
public void setAllowCoreThreadTimeOut(boolean);
descriptor: (Z)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.allowCoreThreadTimeOut:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 2 1 allowCoreThreadTimeOut Z
MethodParameters:
Name Flags
allowCoreThreadTimeOut
public void setTaskDecorator(org.springframework.core.task.TaskDecorator);
descriptor: (Lorg/springframework/core/task/TaskDecorator;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.taskDecorator:Lorg/springframework/core/task/TaskDecorator;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 2 1 taskDecorator Lorg/springframework/core/task/TaskDecorator;
MethodParameters:
Name Flags
taskDecorator
protected java.util.concurrent.ExecutorService initializeExecutor(java.util.concurrent.ThreadFactory, java.util.concurrent.RejectedExecutionHandler);
descriptor: (Ljava/util/concurrent/ThreadFactory;Ljava/util/concurrent/RejectedExecutionHandler;)Ljava/util/concurrent/ExecutorService;
flags: (0x0004) ACC_PROTECTED
Code:
stack=11, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.queueCapacity:I
invokevirtual org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.createQueue:(I)Ljava/util/concurrent/BlockingQueue;
astore 3
start local 3 1: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.taskDecorator:Lorg/springframework/core/task/TaskDecorator;
ifnull 7
2: new org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor$1
dup
aload 0
3: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.corePoolSize:I
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.maxPoolSize:I
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.keepAliveSeconds:I
i2l
getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
4: aload 3
aload 1
aload 2
5: invokespecial org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor$1.<init>:(Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;Ljava/util/concurrent/RejectedExecutionHandler;)V
astore 4
start local 4 6: goto 11
end local 4 7: StackMap locals: java.util.concurrent.BlockingQueue
StackMap stack:
new java.util.concurrent.ThreadPoolExecutor
dup
8: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.corePoolSize:I
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.maxPoolSize:I
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.keepAliveSeconds:I
i2l
getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
9: aload 3
aload 1
aload 2
10: invokespecial java.util.concurrent.ThreadPoolExecutor.<init>:(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;Ljava/util/concurrent/RejectedExecutionHandler;)V
astore 4
start local 4 11: StackMap locals: java.util.concurrent.ThreadPoolExecutor
StackMap stack:
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.allowCoreThreadTimeOut:Z
ifeq 13
12: aload 4
iconst_1
invokevirtual java.util.concurrent.ThreadPoolExecutor.allowCoreThreadTimeOut:(Z)V
13: StackMap locals:
StackMap stack:
aload 0
aload 4
putfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
14: aload 4
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 15 1 threadFactory Ljava/util/concurrent/ThreadFactory;
0 15 2 rejectedExecutionHandler Ljava/util/concurrent/RejectedExecutionHandler;
1 15 3 queue Ljava/util/concurrent/BlockingQueue<Ljava/lang/Runnable;>;
6 7 4 executor Ljava/util/concurrent/ThreadPoolExecutor;
11 15 4 executor Ljava/util/concurrent/ThreadPoolExecutor;
MethodParameters:
Name Flags
threadFactory
rejectedExecutionHandler
protected java.util.concurrent.BlockingQueue<java.lang.Runnable> createQueue(int);
descriptor: (I)Ljava/util/concurrent/BlockingQueue;
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: iload 1
ifle 2
1: new java.util.concurrent.LinkedBlockingQueue
dup
iload 1
invokespecial java.util.concurrent.LinkedBlockingQueue.<init>:(I)V
areturn
2: StackMap locals:
StackMap stack:
new java.util.concurrent.SynchronousQueue
dup
invokespecial java.util.concurrent.SynchronousQueue.<init>:()V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 3 1 queueCapacity I
Signature: (I)Ljava/util/concurrent/BlockingQueue<Ljava/lang/Runnable;>;
MethodParameters:
Name Flags
queueCapacity
public java.util.concurrent.ThreadPoolExecutor getThreadPoolExecutor();
descriptor: ()Ljava/util/concurrent/ThreadPoolExecutor;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
ifnull 1
iconst_1
goto 2
StackMap locals:
StackMap stack:
1: iconst_0
StackMap locals:
StackMap stack: int
2: ldc "ThreadPoolTaskExecutor not initialized"
invokestatic org.springframework.util.Assert.state:(ZLjava/lang/String;)V
3: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
Exceptions:
throws java.lang.IllegalStateException
public int getPoolSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
ifnonnull 2
1: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.corePoolSize:I
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
invokevirtual java.util.concurrent.ThreadPoolExecutor.getPoolSize:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
public int getActiveCount();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
ifnonnull 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
invokevirtual java.util.concurrent.ThreadPoolExecutor.getActiveCount:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
public void execute(java.lang.Runnable);
descriptor: (Ljava/lang/Runnable;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.getThreadPoolExecutor:()Ljava/util/concurrent/ThreadPoolExecutor;
astore 2
start local 2 1: aload 2
aload 1
invokeinterface java.util.concurrent.Executor.execute:(Ljava/lang/Runnable;)V
2: goto 5
3: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.lang.Runnable java.util.concurrent.Executor
StackMap stack: java.util.concurrent.RejectedExecutionException
astore 3
start local 3 4: new org.springframework.core.task.TaskRejectedException
dup
new java.lang.StringBuilder
dup
ldc "Executor ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "] did not accept task: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 3
invokespecial org.springframework.core.task.TaskRejectedException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 3 5: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 6 1 task Ljava/lang/Runnable;
1 6 2 executor Ljava/util/concurrent/Executor;
4 5 3 ex Ljava/util/concurrent/RejectedExecutionException;
Exception table:
from to target type
1 2 3 Class java.util.concurrent.RejectedExecutionException
MethodParameters:
Name Flags
task
public void execute(java.lang.Runnable, long);
descriptor: (Ljava/lang/Runnable;J)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
invokevirtual org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.execute:(Ljava/lang/Runnable;)V
1: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 2 1 task Ljava/lang/Runnable;
0 2 2 startTimeout J
MethodParameters:
Name Flags
task
startTimeout
public java.util.concurrent.Future<?> submit(java.lang.Runnable);
descriptor: (Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.getThreadPoolExecutor:()Ljava/util/concurrent/ThreadPoolExecutor;
astore 2
start local 2 1: aload 2
aload 1
invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
2: areturn
3: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.lang.Runnable java.util.concurrent.ExecutorService
StackMap stack: java.util.concurrent.RejectedExecutionException
astore 3
start local 3 4: new org.springframework.core.task.TaskRejectedException
dup
new java.lang.StringBuilder
dup
ldc "Executor ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "] did not accept task: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 3
invokespecial org.springframework.core.task.TaskRejectedException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 5 1 task Ljava/lang/Runnable;
1 5 2 executor Ljava/util/concurrent/ExecutorService;
4 5 3 ex Ljava/util/concurrent/RejectedExecutionException;
Exception table:
from to target type
1 2 3 Class java.util.concurrent.RejectedExecutionException
Signature: (Ljava/lang/Runnable;)Ljava/util/concurrent/Future<*>;
MethodParameters:
Name Flags
task
public <T> java.util.concurrent.Future<T> submit(java.util.concurrent.Callable<T>);
descriptor: (Ljava/util/concurrent/Callable;)Ljava/util/concurrent/Future;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.getThreadPoolExecutor:()Ljava/util/concurrent/ThreadPoolExecutor;
astore 2
start local 2 1: aload 2
aload 1
invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/util/concurrent/Callable;)Ljava/util/concurrent/Future;
2: areturn
3: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.util.concurrent.Callable java.util.concurrent.ExecutorService
StackMap stack: java.util.concurrent.RejectedExecutionException
astore 3
start local 3 4: new org.springframework.core.task.TaskRejectedException
dup
new java.lang.StringBuilder
dup
ldc "Executor ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "] did not accept task: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 3
invokespecial org.springframework.core.task.TaskRejectedException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 5 1 task Ljava/util/concurrent/Callable<TT;>;
1 5 2 executor Ljava/util/concurrent/ExecutorService;
4 5 3 ex Ljava/util/concurrent/RejectedExecutionException;
Exception table:
from to target type
1 2 3 Class java.util.concurrent.RejectedExecutionException
Signature: <T:Ljava/lang/Object;>(Ljava/util/concurrent/Callable<TT;>;)Ljava/util/concurrent/Future<TT;>;
MethodParameters:
Name Flags
task
public org.springframework.util.concurrent.ListenableFuture<?> submitListenable(java.lang.Runnable);
descriptor: (Ljava/lang/Runnable;)Lorg/springframework/util/concurrent/ListenableFuture;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.getThreadPoolExecutor:()Ljava/util/concurrent/ThreadPoolExecutor;
astore 2
start local 2 1: new org.springframework.util.concurrent.ListenableFutureTask
dup
aload 1
aconst_null
invokespecial org.springframework.util.concurrent.ListenableFutureTask.<init>:(Ljava/lang/Runnable;Ljava/lang/Object;)V
astore 3
start local 3 2: aload 2
aload 3
invokeinterface java.util.concurrent.ExecutorService.execute:(Ljava/lang/Runnable;)V
3: aload 3
4: areturn
end local 3 5: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.lang.Runnable java.util.concurrent.ExecutorService
StackMap stack: java.util.concurrent.RejectedExecutionException
astore 3
start local 3 6: new org.springframework.core.task.TaskRejectedException
dup
new java.lang.StringBuilder
dup
ldc "Executor ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "] did not accept task: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 3
invokespecial org.springframework.core.task.TaskRejectedException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 7 1 task Ljava/lang/Runnable;
1 7 2 executor Ljava/util/concurrent/ExecutorService;
2 5 3 future Lorg/springframework/util/concurrent/ListenableFutureTask<Ljava/lang/Object;>;
6 7 3 ex Ljava/util/concurrent/RejectedExecutionException;
Exception table:
from to target type
1 4 5 Class java.util.concurrent.RejectedExecutionException
Signature: (Ljava/lang/Runnable;)Lorg/springframework/util/concurrent/ListenableFuture<*>;
MethodParameters:
Name Flags
task
public <T> org.springframework.util.concurrent.ListenableFuture<T> submitListenable(java.util.concurrent.Callable<T>);
descriptor: (Ljava/util/concurrent/Callable;)Lorg/springframework/util/concurrent/ListenableFuture;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.getThreadPoolExecutor:()Ljava/util/concurrent/ThreadPoolExecutor;
astore 2
start local 2 1: new org.springframework.util.concurrent.ListenableFutureTask
dup
aload 1
invokespecial org.springframework.util.concurrent.ListenableFutureTask.<init>:(Ljava/util/concurrent/Callable;)V
astore 3
start local 3 2: aload 2
aload 3
invokeinterface java.util.concurrent.ExecutorService.execute:(Ljava/lang/Runnable;)V
3: aload 3
4: areturn
end local 3 5: StackMap locals: org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor java.util.concurrent.Callable java.util.concurrent.ExecutorService
StackMap stack: java.util.concurrent.RejectedExecutionException
astore 3
start local 3 6: new org.springframework.core.task.TaskRejectedException
dup
new java.lang.StringBuilder
dup
ldc "Executor ["
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "] did not accept task: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aload 3
invokespecial org.springframework.core.task.TaskRejectedException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 7 1 task Ljava/util/concurrent/Callable<TT;>;
1 7 2 executor Ljava/util/concurrent/ExecutorService;
2 5 3 future Lorg/springframework/util/concurrent/ListenableFutureTask<TT;>;
6 7 3 ex Ljava/util/concurrent/RejectedExecutionException;
Exception table:
from to target type
1 4 5 Class java.util.concurrent.RejectedExecutionException
Signature: <T:Ljava/lang/Object;>(Ljava/util/concurrent/Callable<TT;>;)Lorg/springframework/util/concurrent/ListenableFuture<TT;>;
MethodParameters:
Name Flags
task
protected void cancelRemainingTask(java.lang.Runnable);
descriptor: (Ljava/lang/Runnable;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokespecial org.springframework.scheduling.concurrent.ExecutorConfigurationSupport.cancelRemainingTask:(Ljava/lang/Runnable;)V
1: aload 0
getfield org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor.decoratedTaskMap:Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
astore 2
start local 2 2: aload 2
instanceof java.util.concurrent.Future
ifeq 4
3: aload 2
checkcast java.util.concurrent.Future
iconst_1
invokeinterface java.util.concurrent.Future.cancel:(Z)Z
pop
4: StackMap locals: java.lang.Object
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/springframework/scheduling/concurrent/ThreadPoolTaskExecutor;
0 5 1 task Ljava/lang/Runnable;
2 5 2 original Ljava/lang/Object;
MethodParameters:
Name Flags
task
}
SourceFile: "ThreadPoolTaskExecutor.java"
NestMembers:
org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor$1
InnerClasses:
org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor$1
public final ReferenceType = org.springframework.util.ConcurrentReferenceHashMap$ReferenceType of org.springframework.util.ConcurrentReferenceHashMap