public class org.apache.dubbo.common.threadpool.ThreadlessExecutor extends java.util.concurrent.AbstractExecutorService
{
private static final org.apache.dubbo.common.logger.Logger logger;
private final java.util.concurrent.BlockingQueue queue;
private java.util.concurrent.ExecutorService sharedExecutor;
private java.util.concurrent.CompletableFuture waitingFuture;
private boolean finished;
private volatile boolean waiting;
private final java.lang.Object lock;
public void <init>(java.util.concurrent.ExecutorService)
{
java.lang.Object v;
java.util.concurrent.LinkedBlockingQueue v;
java.util.concurrent.ExecutorService v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v := @parameter: java.util.concurrent.ExecutorService;
specialinvoke v.<java.util.concurrent.AbstractExecutorService: void <init>()>();
v = new java.util.concurrent.LinkedBlockingQueue;
specialinvoke v.<java.util.concurrent.LinkedBlockingQueue: void <init>()>();
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.BlockingQueue queue> = v;
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean finished> = 0;
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean waiting> = 1;
v = new java.lang.Object;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.lang.Object lock> = v;
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.ExecutorService sharedExecutor> = v;
return;
}
public java.util.concurrent.CompletableFuture getWaitingFuture()
{
java.util.concurrent.CompletableFuture v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.CompletableFuture waitingFuture>;
return v;
}
public void setWaitingFuture(java.util.concurrent.CompletableFuture)
{
java.util.concurrent.CompletableFuture v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v := @parameter: java.util.concurrent.CompletableFuture;
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.CompletableFuture waitingFuture> = v;
return;
}
public boolean isWaiting()
{
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
boolean v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean waiting>;
return v;
}
public void waitAndDrain() throws java.lang.InterruptedException
{
java.lang.Throwable v;
java.util.concurrent.BlockingQueue v, v, v;
java.lang.InterruptedException v;
java.lang.Object v, v, v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
boolean v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean finished>;
if v == 0 goto label;
return;
label:
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: java.lang.Object take()>();
label:
goto label;
label:
v := @caughtexception;
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean waiting> = 0;
throw v;
label:
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.lang.Object lock>;
entermonitor v;
label:
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean waiting> = 0;
interfaceinvoke v.<java.lang.Runnable: void run()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: java.lang.Object poll()>();
label:
if v == null goto label;
interfaceinvoke v.<java.lang.Runnable: void run()>();
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.BlockingQueue queue>;
interfaceinvoke v.<java.util.concurrent.BlockingQueue: java.lang.Object poll()>();
goto label;
label:
v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean finished> = 1;
return;
catch java.lang.InterruptedException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public long waitAndDrain(long, java.util.concurrent.TimeUnit) throws java.lang.InterruptedException, java.util.concurrent.TimeoutException
{
java.util.concurrent.TimeUnit v;
java.lang.UnsupportedOperationException v;
long v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = new java.lang.UnsupportedOperationException;
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>()>();
throw v;
}
public void execute(java.lang.Runnable)
{
java.lang.Throwable v;
java.util.concurrent.BlockingQueue v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor$RunnableWrapper v;
java.lang.Runnable v;
java.lang.Object v;
java.util.concurrent.ExecutorService v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
boolean v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v := @parameter: java.lang.Runnable;
v = new org.apache.dubbo.common.threadpool.ThreadlessExecutor$RunnableWrapper;
specialinvoke v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor$RunnableWrapper: void <init>(java.lang.Runnable)>(v);
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.lang.Object lock>;
entermonitor v;
label:
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: boolean waiting>;
if v != 0 goto label;
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.ExecutorService sharedExecutor>;
interfaceinvoke v.<java.util.concurrent.ExecutorService: void execute(java.lang.Runnable)>(v);
goto label;
label:
v = v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.concurrent.BlockingQueue queue>;
interfaceinvoke v.<java.util.concurrent.BlockingQueue: boolean add(java.lang.Object)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void notifyReturn(java.lang.Throwable)
{
java.lang.Throwable v;
java.lang.Runnable v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v := @parameter: java.lang.Throwable;
v = staticinvoke <org.apache.dubbo.common.threadpool.ThreadlessExecutor$lambda_notifyReturn_0__215: java.lang.Runnable bootstrap$(org.apache.dubbo.common.threadpool.ThreadlessExecutor,java.lang.Throwable)>(v, v);
virtualinvoke v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: void execute(java.lang.Runnable)>(v);
return;
}
public void shutdown()
{
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
virtualinvoke v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: java.util.List shutdownNow()>();
return;
}
public java.util.List shutdownNow()
{
java.lang.IllegalStateException v;
java.util.List v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Consumer is shutting down and this call is going to be stopped without receiving any result, usually this is called by a slow provider instance or bad service implementation.");
virtualinvoke v.<org.apache.dubbo.common.threadpool.ThreadlessExecutor: void notifyReturn(java.lang.Throwable)>(v);
v = staticinvoke <java.util.Collections: java.util.List emptyList()>();
return v;
}
public boolean isShutdown()
{
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
return 0;
}
public boolean isTerminated()
{
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
return 0;
}
public boolean awaitTermination(long, java.util.concurrent.TimeUnit) throws java.lang.InterruptedException
{
java.util.concurrent.TimeUnit v;
long v;
org.apache.dubbo.common.threadpool.ThreadlessExecutor v;
v := @this: org.apache.dubbo.common.threadpool.ThreadlessExecutor;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
return 0;
}
static void <clinit>()
{
java.lang.Class v;
java.lang.String v;
org.apache.dubbo.common.logger.Logger v;
v = class "Lorg/apache/dubbo/common/threadpool/ThreadlessExecutor;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.dubbo.common.logger.LoggerFactory: org.apache.dubbo.common.logger.Logger getLogger(java.lang.String)>(v);
<org.apache.dubbo.common.threadpool.ThreadlessExecutor: org.apache.dubbo.common.logger.Logger logger> = v;
return;
}
}