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


Java ExecutorService.awaitTermination方法代碼示例

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


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

示例1: B0_warm_up

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

    List<Dummy> result = synchronizedList(new ArrayList<>());

    ExecutorService executor = newFixedThreadPool(FIFTEEN_15);

    for (int i = 0; i < ONE_MILLION; i++) {
        executor.submit(() -> {
            String json = randomJsonPool.get(random.nextInt(ONE_MILLION));
            Payload<Dummy> payload = JSON.payload().newInstance(json, Dummy.class);
            result.add(payload.get());
            result.add(gson.fromJson(json, Dummy.class));
        });
    }

    executor.shutdown();
    executor.awaitTermination(10, SECONDS);

    assertThat(result.size()).isEqualTo(ONE_MILLION * 2);
}
 
開發者ID:juliaaano,項目名稱:payload,代碼行數:22,代碼來源:JsonBenchmark.java

示例2: shutdown

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public static void shutdown(ExecutorService exec, Duration timeout){
	Duration halfTimeout = timeout.dividedBy(2);
	long halfTimeoutMs = timeout.toMillis();
	logger.info("shutting down {}", exec);
	exec.shutdown();
	try{
		if(!exec.awaitTermination(halfTimeoutMs, TimeUnit.MILLISECONDS)){
			logger.warn("{} did not shut down after {}, interrupting", exec, halfTimeout);
			exec.shutdownNow();
			if(!exec.awaitTermination(halfTimeoutMs, TimeUnit.MILLISECONDS)){
				logger.error("could not shut down {} after {}", exec, timeout);
			}
		}
	}catch(InterruptedException e){
		logger.warn("interrupted while waiting for {} to shut down", exec);
		exec.shutdownNow();
		Thread.currentThread().interrupt();
	}
}
 
開發者ID:hotpads,項目名稱:datarouter,代碼行數:20,代碼來源:ExecutorServiceTool.java

示例3: stateSetTest

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
@Test
public void stateSetTest() throws InterruptedException {
    Network network = EurostagTutorialExample1Factory.create();
    StateManager manager = network.getStateManager();
    manager.allowStateMultiThreadAccess(true);
    assertTrue(manager.getWorkingStateId().equals(StateManager.INITIAL_STATE_ID));
    ExecutorService service = Executors.newSingleThreadExecutor();
    service.submit(() -> {
        try {
            manager.setWorkingState(StateManager.INITIAL_STATE_ID);
            network.getGenerator("GEN").getTargetP();
        } catch (Exception e) {
            fail();
        }
    });
    service.shutdown();
    service.awaitTermination(1, TimeUnit.MINUTES);
}
 
開發者ID:powsybl,項目名稱:powsybl-core,代碼行數:19,代碼來源:MultiStateNetworkTest.java

示例4: testInterruption

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
@Test
public void testInterruption() throws InterruptedException {
  ExecutorService threadPool = Executors.newFixedThreadPool(10);
  SequentialQueue<Integer> queue = new SequentialQueue<>(10);

  threadPool.submit(Interrupted.unchecked(() -> queue.dequeue()));

  threadPool.submit(Interrupted.unchecked(() -> {
    for (int i = 0; i < 200; i++) {
      queue.dequeue();
    }
  }));

  for (int i = 0; i < 100; i++) {
    final int index = i;
    threadPool.submit(Interrupted.unchecked(() -> {
      queue.enqueue(index, null);
    }));
  }

  queue.enqueueException(100, new ClassCastException());

  threadPool.shutdown();
  threadPool.awaitTermination(Long.MAX_VALUE, TimeUnit.NANOSECONDS);
}
 
開發者ID:linkedin,項目名稱:concurrentli,代碼行數:26,代碼來源:SequentialQueueTest.java

示例5: testGraphCreate

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public List testGraphCreate(String userId, long count, int poolSize, GraphDataObject[] graph, Class serviceClazz) {
    ExecutorService executor = Executors.newFixedThreadPool(poolSize);

    for (int i = 0; i < count; i++) {
        GraphCreateThread tt = new GraphCreateThread(this, userId, graph[i], serviceClazz);

        executor.execute(tt);
    }
    executor.shutdown();
    try {
        executor.awaitTermination(Integer.MAX_VALUE, TimeUnit.SECONDS);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    return getUpdateResponses();
}
 
開發者ID:jaffa-projects,項目名稱:jaffa-framework,代碼行數:17,代碼來源:CreateGraphTest.java

示例6: testMultipleClients

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
@Test
public void testMultipleClients() throws Exception {
  ExecutorService exec = Executors.newFixedThreadPool(NUM_THREADS);
  try {
    ExecutorCompletionService<Boolean> ecs =
        new ExecutorCompletionService<Boolean>(exec);
    for (int i = 0; i < NUM_THREADS; ++i)
      ecs.submit(new IdLockTestThread("client_" + i));
    for (int i = 0; i < NUM_THREADS; ++i) {
      Future<Boolean> result = ecs.take();
      assertTrue(result.get());
    }
    idLock.assertMapEmpty();
  } finally {
    exec.shutdown();
    exec.awaitTermination(5000, TimeUnit.MILLISECONDS);
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:19,代碼來源:TestIdLock.java

示例7: shutdownAndAwaitTermination

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * Shutdown cordova thread pool. This assumes we are in control of all tasks running
 * in the thread pool.
 * Additional info: http://developer.android.com/reference/java/util/concurrent/ExecutorService.html
 * @param pool Cordova application's thread pool
 */
private void shutdownAndAwaitTermination(ExecutorService pool) {
    Log.d(TAG,"Attempting to shutdown cordova threadpool");
    if(!pool.isShutdown()){
        try {
            // Disable new tasks from being submitted
            pool.shutdown();
            // Wait a while for existing tasks to terminate
            if (!pool.awaitTermination(5, TimeUnit.SECONDS)) {
                pool.shutdownNow(); // Cancel currently executing tasks
                // Wait a while for tasks to respond to being cancelled
                if (!pool.awaitTermination(30, TimeUnit.SECONDS)) {
                    System.err.println("Cordova thread pool did not terminate.");
                }
            }
        }
        catch (InterruptedException ie) {
            // Preserve interrupt status
            Thread.currentThread().interrupt();
        }
    }
}
 
開發者ID:SUTFutureCoder,項目名稱:localcloud_fe,代碼行數:28,代碼來源:AdvancedGeolocation.java

示例8: getList

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/** 根據Id查詢(默認類型T) */
public List<T> getList(List<Long> ids) {
	List<T> list = InstanceUtil.newArrayList();
	if (ids != null) {
		for (int i = 0; i < ids.size(); i++) {
			list.add(null);
		}
		ExecutorService executorService = Executors.newFixedThreadPool(10);
		for (int i = 0; i < ids.size(); i++) {
			final int index = i;
			executorService.execute(new Runnable() {
				public void run() {
					list.set(index, queryById(ids.get(index)));
				}
			});
		}
		executorService.shutdown();
		try {
			executorService.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
		} catch (InterruptedException e) {
			logger.error("awaitTermination", "", e);
		}
	}
	return list;
}
 
開發者ID:guokezheng,項目名稱:automat,代碼行數:26,代碼來源:BaseService.java

示例9: testDirectExecutorService_awaitTermination_missedSignal

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * Test for a bug where threads weren't getting signaled when shutdown was called, only when
 * tasks completed.
 */

public void testDirectExecutorService_awaitTermination_missedSignal() {
  final ExecutorService service = MoreExecutors.newDirectExecutorService();
  Thread waiter = new Thread() {
    @Override public void run() {
      try {
        service.awaitTermination(1, TimeUnit.DAYS);
      } catch (InterruptedException e) {
        return;
      }
    }
  };
  waiter.start();
  awaitTimedWaiting(waiter);
  service.shutdown();
  Uninterruptibles.joinUninterruptibly(waiter, 10, TimeUnit.SECONDS);
  if (waiter.isAlive()) {
    waiter.interrupt();
    fail("awaitTermination failed to trigger after shutdown()");
  }
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:26,代碼來源:MoreExecutorsTest.java

示例10: destroy

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
@Override
public void destroy() throws Exception {
    StopWatch stopWatch = new StopWatch();
    stopWatch.start();

    if (isClose.compareAndSet(false, true)) {
        logger.info("HBaseTemplate2.destroy()");
        final ExecutorService executor = this.executor;
        if (executor != null) {
            executor.shutdown();
            try {
                executor.awaitTermination(DEFAULT_DESTORY_TIMEOUT, TimeUnit.MILLISECONDS);
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt();
            }
        }

        long remainingTime = Math.max(DEFAULT_DESTORY_TIMEOUT - stopWatch.stop(), 100);
        awaitAsyncPutOpsCleared(remainingTime, 50);
    }
}
 
開發者ID:fchenxi,項目名稱:easyhbase,代碼行數:22,代碼來源:HbaseTemplate2.java

示例11: main

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public static void main(String[] arg)
{
   // construct the shared object
   SimpleArray sharedSimpleArray = new SimpleArray(6);

   // create two tasks to write to the shared SimpleArray
   ArrayWriter writer1 = new ArrayWriter(1, sharedSimpleArray);
   ArrayWriter writer2 = new ArrayWriter(11, sharedSimpleArray);

   // execute the tasks with an ExecutorService
   ExecutorService executorService = Executors.newCachedThreadPool();
   executorService.execute(writer1);
   executorService.execute(writer2);

   executorService.shutdown();

   try
   {
      // wait 1 minute for both writers to finish executing
      boolean tasksEnded = 
         executorService.awaitTermination(1, TimeUnit.MINUTES);

      if (tasksEnded)
      {
         System.out.printf("%nContents of SimpleArray:%n");
         System.out.println(sharedSimpleArray); // print contents
      }
      else
         System.out.println(
            "Timed out while waiting for tasks to finish.");
   } 
   catch (InterruptedException ex)
   {
      ex.printStackTrace();
   } 
}
 
開發者ID:cleitonferreira,項目名稱:LivroJavaComoProgramar10Edicao,代碼行數:37,代碼來源:SharedArrayTest.java

示例12: terminate

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * Returns <code>true</code> if the given service was terminated successfully. If the termination timed out,
 * the service is <code>null</code> this method will return <code>false</code>.
 */
public static boolean terminate(ExecutorService service, long timeout, TimeUnit timeUnit) {
    if (service != null) {
        service.shutdown();
        try {
            if (service.awaitTermination(timeout, timeUnit)) {
                return true;
            }
        } catch (InterruptedException e) {
            Thread.currentThread().interrupt();
        }
        service.shutdownNow();
    }
    return false;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:19,代碼來源:ThreadPool.java

示例13: testWrite_MultipleWriters

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
   * Test for multiple writers running in separate threads, writing data simultaneously.
   */
  @Test
  public void testWrite_MultipleWriters() throws RMIException, IOException, InterruptedException {
//    System.out.println("MonarchRecordWriterTest.testWrite_MultipleWriters");
    final List<String> lines = TestHelper.getResourceAsString(resourceFile);
    final Map<String, Integer> expectedMap = new HashMap<String, Integer>(4) {{
      put("0", 10);
      put("1", 10);
      put("2", 10);
      put("3", 1);
    }};
    final int blockSize = 10;

    ExecutorService es = Executors.newFixedThreadPool(3);
    for (int i = 0; i < 3; i++) {
      final String tid = "000_" + i;
      es.submit(() -> {
        try {
          assertOnRecordWriter(lines, expectedMap, tid, blockSize);
        } catch (Exception e) {
          fail("No exception expected: " + e.getMessage());
        }
      });
    }
    es.shutdown();
    es.awaitTermination(5, TimeUnit.SECONDS);
    if (!es.isTerminated()) {
      es.shutdownNow();
    }
    Configuration conf = new Configuration();
    conf.set("monarch.locator.port", testBase.getLocatorPort());
  }
 
開發者ID:ampool,項目名稱:monarch,代碼行數:35,代碼來源:MonarchRecordWriterTest.java

示例14: main

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
		int count=1;
		ExecutorService pool = Executors.newFixedThreadPool(128);
		System.out.println("5555555555555555:"+client.connectionPool().connectionCount());
		while (count<=10) {
			pool.execute(new Runnable() {
				@Override
				public void run() {
					for(int i=0;i<100;i++){
//						RequestBody formBody =new FormBody.Builder()
//			            .add("q",selectSql)
//			            .build();
//						Request request = new Request.Builder()
//						.url(QUERY_URL)
//						.header("Connection", "close")
//						.post(formBody)
//						.build();
//						client.newCall(request).execute();
						MediaType MEDIA_TYPE_TEXT = MediaType.parse("text/plain");
						String postBody = "Hello World";
						Request request = new Request.Builder()
						.url("http://cc.0071515.com/")
//						.header("Connection", "close")
						.post(RequestBody.create(MEDIA_TYPE_TEXT, postBody))
						.build();
						long st = System.currentTimeMillis();
						try {
							Response response = client.newCall(request).execute();
							System.out.println(response.code());
							response.close();
						} catch (IOException e) {
							e.printStackTrace();
						}
						long et = System.currentTimeMillis();
						System.out.println(client.connectionPool().connectionCount());
//						System.out.println(et-st);
//						client.dispatcher().executorService().shutdown();
//						try {
//							 client.connectionPool().evictAll();
//						} catch (Exception e) {
//							e.printStackTrace();
//						}
//						long startTime = System.currentTimeMillis();
//						System.currentTimeMillis();
					}
				}
			});
			count++;
		}
		pool.shutdown();
		pool.awaitTermination(10, TimeUnit.DAYS);
//	    if (!response.isSuccessful()) throw new IOException("Unexpected code " + response);
//	 
//	    Headers responseHeaders = response.headers();
//	    for (int i = 0; i < responseHeaders.size(); i++) {
//	      System.out.println(responseHeaders.name(i) + ": " + responseHeaders.value(i));
//	    }
//	 
//	    System.out.println(response.body().string());
	}
 
開發者ID:dbiir,項目名稱:ts-benchmark,代碼行數:61,代碼來源:OkHttpTest.java

示例15: testRemovalNotification_get_basher

import java.util.concurrent.ExecutorService; //導入方法依賴的package包/類
/**
 * Calls get() repeatedly from many different threads, and tests that all of the removed entries
 * (removed because of size limits or expiration) trigger appropriate removal notifications.
 */
@GwtIncompatible // QueuingRemovalListener

public void testRemovalNotification_get_basher() throws InterruptedException {
  int nTasks = 1000;
  int nThreads = 100;
  final int getsPerTask = 1000;
  final int nUniqueKeys = 10000;
  final Random random = new Random(); // Randoms.insecureRandom();

  QueuingRemovalListener<String, String> removalListener = queuingRemovalListener();
  final AtomicInteger computeCount = new AtomicInteger();
  final AtomicInteger exceptionCount = new AtomicInteger();
  final AtomicInteger computeNullCount = new AtomicInteger();
  CacheLoader<String, String> countingIdentityLoader =
      new CacheLoader<String, String>() {
        @Override public String load(String key) throws InterruptedException {
          int behavior = random.nextInt(4);
          if (behavior == 0) { // throw an exception
            exceptionCount.incrementAndGet();
            throw new RuntimeException("fake exception for test");
          } else if (behavior == 1) { // return null
            computeNullCount.incrementAndGet();
            return null;
          } else if (behavior == 2) { // slight delay before returning
            Thread.sleep(5);
            computeCount.incrementAndGet();
            return key;
          } else {
            computeCount.incrementAndGet();
            return key;
          }
        }
      };
  final LoadingCache<String, String> cache = CacheBuilder.newBuilder()
      .recordStats()
      .concurrencyLevel(2)
      .expireAfterWrite(100, TimeUnit.MILLISECONDS)
      .removalListener(removalListener)
      .maximumSize(5000)
      .build(countingIdentityLoader);

  ExecutorService threadPool = Executors.newFixedThreadPool(nThreads);
  for (int i = 0; i < nTasks; i++) {
    @SuppressWarnings("unused") // go/futurereturn-lsc
    Future<?> possiblyIgnoredError =
        threadPool.submit(
            new Runnable() {
              @Override
              public void run() {
                for (int j = 0; j < getsPerTask; j++) {
                  try {
                    cache.getUnchecked("key" + random.nextInt(nUniqueKeys));
                  } catch (RuntimeException e) {
                  }
                }
              }
            });
  }

  threadPool.shutdown();
  threadPool.awaitTermination(300, TimeUnit.SECONDS);

  // Since we're not doing any more cache operations, and the cache only expires/evicts when doing
  // other operations, the cache and the removal queue won't change from this point on.

  // Verify that each received removal notification was valid
  for (RemovalNotification<String, String> notification : removalListener) {
    assertEquals("Invalid removal notification", notification.getKey(), notification.getValue());
  }

  CacheStats stats = cache.stats();
  assertEquals(removalListener.size(), stats.evictionCount());
  assertEquals(computeCount.get(), stats.loadSuccessCount());
  assertEquals(exceptionCount.get() + computeNullCount.get(), stats.loadExceptionCount());
  // each computed value is still in the cache, or was passed to the removal listener
  assertEquals(computeCount.get(), cache.size() + removalListener.size());
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:82,代碼來源:CacheBuilderTest.java


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