當前位置: 首頁>>代碼示例>>Java>>正文


Java ThreadPoolExecutor.getQueue方法代碼示例

本文整理匯總了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();
            }
        }
    }
}
 
開發者ID:yu199195,項目名稱:happylifeplat-tcc,代碼行數:25,代碼來源:RejectedPolicy.java

示例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();
            }
        }
    }
}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:25,代碼來源:RejectedPolicy.java

示例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);
        }
    }
}
 
開發者ID:Netflix,項目名稱:sstable-adaptor,代碼行數:26,代碼來源:DebuggableThreadPoolExecutor.java

示例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());
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:21,代碼來源:EsAbortPolicy.java

示例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<>();
}
 
開發者ID:MaYunFei,項目名稱:RxJavaDownLoadMultipleFile,代碼行數:20,代碼來源:DownloadManager.java

示例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();
            }
        }
    }
}
 
開發者ID:yu199195,項目名稱:myth,代碼行數:25,代碼來源:RejectedPolicy.java

示例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();
}
 
開發者ID:LaurenceYang,項目名稱:EasyHttp,代碼行數:17,代碼來源:EasyDownloadManager.java

示例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();
        }
    };
}
 
開發者ID:miLLlulei,項目名稱:Accessibility,代碼行數:30,代碼來源:AndroidUtilsCompat.java

示例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);
    }
}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:16,代碼來源:DiscardedPolicy.java

示例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);
    }
}
 
開發者ID:yu199195,項目名稱:happylifeplat-tcc,代碼行數:15,代碼來源:DiscardedPolicy.java

示例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);
    }
}
 
開發者ID:yu199195,項目名稱:myth,代碼行數:15,代碼來源:DiscardedPolicy.java

示例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();
}
 
開發者ID:LaurenceYang,項目名稱:EasyHttp,代碼行數:14,代碼來源:EasySimpleDownloadManager.java

示例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();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:10,代碼來源:JSR166TestCase.java


注:本文中的java.util.concurrent.ThreadPoolExecutor.getQueue方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。