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


Java ThreadPoolExecutor.setKeepAliveTime方法代碼示例

本文整理匯總了Java中java.util.concurrent.ThreadPoolExecutor.setKeepAliveTime方法的典型用法代碼示例。如果您正苦於以下問題:Java ThreadPoolExecutor.setKeepAliveTime方法的具體用法?Java ThreadPoolExecutor.setKeepAliveTime怎麽用?Java ThreadPoolExecutor.setKeepAliveTime使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.concurrent.ThreadPoolExecutor的用法示例。


在下文中一共展示了ThreadPoolExecutor.setKeepAliveTime方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testKeepAliveTimeIllegalArgumentException

import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
/**
 * setKeepAliveTime throws IllegalArgumentException
 * when given a negative value
 */
public void testKeepAliveTimeIllegalArgumentException() {
    final ThreadPoolExecutor p =
        new CustomTPE(2, 3,
                      LONG_DELAY_MS, MILLISECONDS,
                      new ArrayBlockingQueue<Runnable>(10));
    try (PoolCleaner cleaner = cleaner(p)) {
        try {
            p.setKeepAliveTime(-1, MILLISECONDS);
            shouldThrow();
        } catch (IllegalArgumentException success) {}
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:ThreadPoolExecutorSubclassTest.java

示例2: testKeepAliveTimeIllegalArgumentException

import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
/**
 * setKeepAliveTime throws IllegalArgumentException
 * when given a negative value
 */
public void testKeepAliveTimeIllegalArgumentException() {
    final ThreadPoolExecutor p =
        new ThreadPoolExecutor(2, 3,
                               LONG_DELAY_MS, MILLISECONDS,
                               new ArrayBlockingQueue<Runnable>(10));
    try (PoolCleaner cleaner = cleaner(p)) {
        try {
            p.setKeepAliveTime(-1, MILLISECONDS);
            shouldThrow();
        } catch (IllegalArgumentException success) {}
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:ThreadPoolExecutorTest.java

示例3: positiveTest

import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Test
public void positiveTest() {

    // create the threads manager
    this.threadsManager = new ThreadsManager();

    // create all the threads
    ThreadPoolExecutor executor = ( ThreadPoolExecutor ) Executors.newCachedThreadPool();
    executor.setKeepAliveTime( 0, TimeUnit.SECONDS );
    ExecutorCompletionService<Object> executionService = new ExecutorCompletionService<Object>( executor );

    IterationListener listener = new IterationListener();

    msg( log, "Ask Java to create all threads" );
    for( int j = 0; j < N_THREADS; j++ ) {
        executionService.submit( new TestWorker( N_ITERATIONS, threadsManager, listener ), null );
    }

    // run all iterations
    for( int i = 0; i < N_ITERATIONS; i++ ) {
        msg( log, "ITERATION " + i + "\n\n" );
        runThisIteration();

        waitForIterationCompletion();
    }

    // it may take a little while all threads are gone
    try {
        Thread.sleep( 1000 );
    } catch( InterruptedException e ) {}

    // check if there are any remaining threads started by this test
    checkAllRemainingThreads();
}
 
開發者ID:Axway,項目名稱:ats-framework,代碼行數:35,代碼來源:Test_ThreadsManager.java

示例4: initExecutionPool

import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
private void initExecutionPool(int corePoolSize, int maxPoolSize, long keepAliveTime) {
  executorPool = (ThreadPoolExecutor) Executors.newCachedThreadPool();
  executorPool.setCorePoolSize(corePoolSize);
  executorPool.setMaximumPoolSize(maxPoolSize);
  executorPool.setKeepAliveTime(keepAliveTime, TimeUnit.MILLISECONDS);

}
 
開發者ID:DSC-SPIDAL,項目名稱:twister2,代碼行數:8,代碼來源:TaskExecutorCachedThreadPool.java

示例5: scheduleThreads

import java.util.concurrent.ThreadPoolExecutor; //導入方法依賴的package包/類
@Override
public synchronized void
        scheduleThreads( String caller,
                         boolean isUseSynchronizedIterations ) throws ActionExecutionException,
                                                               ActionTaskLoaderException,
                                                               NoSuchComponentException,
                                                               NoSuchActionException,
                                                               NoCompatibleMethodFoundException,
                                                               ThreadingPatternNotSupportedException {

    //check the state first
    if (state != ActionTaskLoaderState.NOT_STARTED) {
        throw new ActionTaskLoaderException("Cannot schedule load queue " + queueName
                                            + " - it has already been scheduled");
    }

    //create the executor - terminate threads when finished
    ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newCachedThreadPool();
    executor.setKeepAliveTime(0, TimeUnit.SECONDS);

    ExecutorCompletionService<Object> executionService = new ExecutorCompletionService<Object>(executor);

    //synchronization aids
    threadsManagers = new ArrayList<ThreadsManager>();

    // create the thread for managing max iteration length
    int iterationTimeout = startPattern.getIterationTimeout();
    if (iterationTimeout > 0) {
        itManager = new IterationTimeoutManager(iterationTimeout);
    }

    taskFutures = new ArrayList<Future<Object>>();

    for (int i = 0; i < numThreadGroups; i++) {

        //create the thread iterations manager for this group
        ThreadsManager threadsManager = new ThreadsManager();

        int numThreadsInGroup = (i != numThreadGroups - 1)
                                                           ? numThreadsPerStep
                                                           : numThreadsInLastGroup;
        //distribute executions per timeFrame according to the number of threads
        int executionsPerTimeFrame = executionPattern.getExecutionsPerTimeFrame();
        int[] executionsPerTimeFramePerThread = new EvenLoadDistributingUtils().getEvenLoad(executionsPerTimeFrame,
                                                                                            numThreads);
        if (numThreads > executionsPerTimeFrame && executionsPerTimeFrame > 0) {
            throw new ActionTaskLoaderException("We cannot evenly distribute " + executionsPerTimeFrame
                                                + " iterations per time frame to " + numThreads
                                                + " threads. Iterations per time frame must be at least as many as threads!");
        }

        for (int j = 0; j < numThreadsInGroup; j++) {
            Future<Object> taskFuture = executionService.submit(ActionTaskFactory.createTask(caller,
                                                                                             queueName,
                                                                                             executionPattern,
                                                                                             executionsPerTimeFramePerThread[j],
                                                                                             threadsManager,
                                                                                             itManager,
                                                                                             actionRequests,
                                                                                             parameterDataProviders,
                                                                                             defaultTaskListeners,
                                                                                             isUseSynchronizedIterations),
                                                                null);
            taskFutures.add(taskFuture);
        }

        threadsManagers.add(threadsManager);
    }

    state = ActionTaskLoaderState.SCHEDULED;
}
 
開發者ID:Axway,項目名稱:ats-framework,代碼行數:72,代碼來源:RampUpQueueLoader.java


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