本文整理匯總了Java中java.util.concurrent.ThreadPoolExecutor.getQueue方法的典型用法代碼示例。如果您正苦於以下問題:Java ThreadPoolExecutor.getQueue方法的具體用法?Java ThreadPoolExecutor.getQueue怎麽用?Java ThreadPoolExecutor.getQueue使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.util.concurrent.ThreadPoolExecutor
的用法示例。
在下文中一共展示了ThreadPoolExecutor.getQueue方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
if (threadName != null) {
LOG.error("tccTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
}
if (runnable instanceof RejectedRunnable) {
((RejectedRunnable) runnable).rejected();
} else {
if (!executor.isShutdown()) {
BlockingQueue<Runnable> queue = executor.getQueue();
int discardSize = queue.size() >> 1;
for (int i = 0; i < discardSize; i++) {
queue.poll();
}
try {
queue.put(runnable);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
示例2: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
if (threadName != null) {
LOG.error("txTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
}
if (runnable instanceof RejectedRunnable) {
((RejectedRunnable) runnable).rejected();
} else {
if (!executor.isShutdown()) {
BlockingQueue<Runnable> queue = executor.getQueue();
int discardSize = queue.size() >> 1;
for (int i = 0; i < discardSize; i++) {
queue.poll();
}
try {
queue.put(runnable);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
示例3: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
public void rejectedExecution(Runnable task, ThreadPoolExecutor executor)
{
((DebuggableThreadPoolExecutor) executor).onInitialRejection(task);
BlockingQueue<Runnable> queue = executor.getQueue();
while (true)
{
if (executor.isShutdown())
{
((DebuggableThreadPoolExecutor) executor).onFinalRejection(task);
throw new RejectedExecutionException("ThreadPoolExecutor has shut down");
}
try
{
if (queue.offer(task, 1000, TimeUnit.MILLISECONDS))
{
((DebuggableThreadPoolExecutor) executor).onFinalAccept(task);
break;
}
}
catch (InterruptedException e)
{
throw new AssertionError(e);
}
}
}
示例4: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
if (r instanceof AbstractRunnable) {
if (((AbstractRunnable) r).isForceExecution()) {
BlockingQueue<Runnable> queue = executor.getQueue();
if (!(queue instanceof SizeBlockingQueue)) {
throw new IllegalStateException("forced execution, but expected a size queue");
}
try {
((SizeBlockingQueue) queue).forcePut(r);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
throw new IllegalStateException("forced execution, but got interrupted", e);
}
return;
}
}
rejected.inc();
throw new EsRejectedExecutionException("rejected execution of " + r + " on " + executor, executor.isShutdown());
}
示例5: init
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
public void init(Context context, int count, Retrofit retrofit) {
mContext = context.getApplicationContext();
mDao = new DownloadDao(context.getApplicationContext());
mDao.pauseAll();
mThreadCount = count;
mExecutor = new ThreadPoolExecutor(mThreadCount, mThreadCount, 2000, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>());
mThreadQueue = (LinkedBlockingQueue<Runnable>) mExecutor.getQueue();
if (retrofit == null) {
retrofit =
new Retrofit.Builder().baseUrl("http://blog.csdn.net/zggzcgy/article/details/23987637/")
.client(getOkHttpClient())
.build();
}
mRetrofit = retrofit;
//下載api
mDownloadApi = mRetrofit.create(DownloadApi.class);
mCurrentTaskList = new LinkedHashMap<>();
}
示例6: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
if (threadName != null) {
LOG.error("MythTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
}
if (runnable instanceof RejectedRunnable) {
((RejectedRunnable) runnable).rejected();
} else {
if (!executor.isShutdown()) {
BlockingQueue<Runnable> queue = executor.getQueue();
int discardSize = queue.size() >> 1;
for (int i = 0; i < discardSize; i++) {
queue.poll();
}
try {
queue.put(runnable);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
示例7: init
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
public void init(Context context, int threadCount, OkHttpClient client) {
setupDatabase(context);
recoveryTaskState();
mClient = client;
mThreadCount = threadCount < 1 ? 1 : threadCount <= EasyConstants.MAX_THREAD_COUNT ? threadCount : EasyConstants.MAX_THREAD_COUNT;
mExecutor = new ThreadPoolExecutor(
mThreadCount,
mThreadCount,
20,
TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>()
);
mCurrentTaskList = new HashMap<>();
mQueue = (LinkedBlockingQueue<Runnable>) mExecutor.getQueue();
}
示例8: getDefaultAsyncTaskNamesOnRejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
/**
* 在AsyncTask發生RejectedExecution時獲取AsyncTask中任務類的外部類名稱(如:new AsyncTask()匿名內部類所在的外部類),
* 便於檢查哪些任務被拒絕、哪些任務在隊列裏、哪些任務存在死循環問題;
*
* @return
*/
public static GetAsyncTaskNamesProxyOnRejectedExecution getDefaultAsyncTaskNamesOnRejectedExecution() {
return new GetAsyncTaskNamesProxyOnRejectedExecution() {
@Override
public String getAsyncTaskNames(Runnable r, ThreadPoolExecutor executor) {
StringBuilder result = new StringBuilder();
result.append("r.OuterClass = " + getOuterClass(r));
result.append("\nqueue.runnable.OuterClasses = [");
BlockingQueue<Runnable> queue = executor.getQueue();
boolean isFirst = false;
for (Runnable task : queue) {
if (!isFirst) {
isFirst = true;
} else {
result.append("\n");
}
Object outerClass = getOuterClass(task);
result.append(outerClass);
}
result.append("]");
return result.toString();
}
};
}
示例9: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
if (threadName != null) {
LOG.error("txTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
}
if (!executor.isShutdown()) {
BlockingQueue<Runnable> queue = executor.getQueue();
int discardSize = queue.size() >> 1;
for (int i = 0; i < discardSize; i++) {
queue.poll();
}
queue.offer(runnable);
}
}
示例10: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
if (threadName != null) {
LOG.error("tccTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
}
if (!executor.isShutdown()) {
BlockingQueue<Runnable> queue = executor.getQueue();
int discardSize = queue.size() >> 1;
for (int i = 0; i < discardSize; i++) {
queue.poll();
}
queue.offer(runnable);
}
}
示例11: rejectedExecution
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
if (threadName != null) {
LOG.error("MythTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
}
if (!executor.isShutdown()) {
BlockingQueue<Runnable> queue = executor.getQueue();
int discardSize = queue.size() >> 1;
for (int i = 0; i < discardSize; i++) {
queue.poll();
}
queue.offer(runnable);
}
}
示例12: init
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
public void init(Context context, int threadCount, OkHttpClient client) {
mClient = client;
mThreadCount = threadCount < 1 ? 1 : threadCount <= EasyConstants.MAX_THREAD_COUNT ? threadCount : EasyConstants.MAX_THREAD_COUNT;
mExecutor = new ThreadPoolExecutor(
mThreadCount,
mThreadCount,
20,
TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>()
);
mCurrentTaskList = new HashMap<>();
mQueue = (LinkedBlockingQueue<Runnable>) mExecutor.getQueue();
}
示例13: saturatedSize
import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
/**
* Returns maximum number of tasks that can be submitted to given
* pool (with bounded queue) before saturation (when submission
* throws RejectedExecutionException).
*/
static final int saturatedSize(ThreadPoolExecutor pool) {
BlockingQueue<Runnable> q = pool.getQueue();
return pool.getMaximumPoolSize() + q.size() + q.remainingCapacity();
}