本文整理匯總了Java中java.util.concurrent.CompletionService類的典型用法代碼示例。如果您正苦於以下問題:Java CompletionService類的具體用法?Java CompletionService怎麽用?Java CompletionService使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
CompletionService類屬於java.util.concurrent包,在下文中一共展示了CompletionService類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: testContainerLocalizerClosesFilesystems
import java.util.concurrent.CompletionService; //導入依賴的package包/類
@Test
@SuppressWarnings("unchecked") // mocked generics
public void testContainerLocalizerClosesFilesystems() throws Exception {
// verify filesystems are closed when localizer doesn't fail
FileContext fs = FileContext.getLocalFSFileContext();
spylfs = spy(fs.getDefaultFileSystem());
ContainerLocalizer localizer = setupContainerLocalizerForTest();
doNothing().when(localizer).localizeFiles(any(LocalizationProtocol.class),
any(CompletionService.class), any(UserGroupInformation.class));
verify(localizer, never()).closeFileSystems(
any(UserGroupInformation.class));
localizer.runLocalization(nmAddr);
verify(localizer).closeFileSystems(any(UserGroupInformation.class));
spylfs = spy(fs.getDefaultFileSystem());
// verify filesystems are closed when localizer fails
localizer = setupContainerLocalizerForTest();
doThrow(new YarnRuntimeException("Forced Failure")).when(localizer).localizeFiles(
any(LocalizationProtocol.class), any(CompletionService.class),
any(UserGroupInformation.class));
verify(localizer, never()).closeFileSystems(
any(UserGroupInformation.class));
localizer.runLocalization(nmAddr);
verify(localizer).closeFileSystems(any(UserGroupInformation.class));
}
示例2: solveAny
import java.util.concurrent.CompletionService; //導入依賴的package包/類
void solveAny(Executor e,
Collection<Callable<Integer>> solvers)
throws InterruptedException {
CompletionService<Integer> cs
= new ExecutorCompletionService<>(e);
int n = solvers.size();
List<Future<Integer>> futures = new ArrayList<>(n);
Integer result = null;
try {
solvers.forEach(solver -> futures.add(cs.submit(solver)));
for (int i = n; i > 0; i--) {
try {
Integer r = cs.take().get();
if (r != null) {
result = r;
break;
}
} catch (ExecutionException ignore) {}
}
} finally {
futures.forEach(future -> future.cancel(true));
}
if (result != null)
use(result);
}
示例3: testPoll1
import java.util.concurrent.CompletionService; //導入依賴的package包/類
/**
* poll returns non-null when the returned task is completed
*/
public void testPoll1()
throws InterruptedException, ExecutionException {
CompletionService cs = new ExecutorCompletionService(cachedThreadPool);
assertNull(cs.poll());
cs.submit(new StringTask());
long startTime = System.nanoTime();
Future f;
while ((f = cs.poll()) == null) {
if (millisElapsedSince(startTime) > LONG_DELAY_MS)
fail("timed out");
Thread.yield();
}
assertTrue(f.isDone());
assertSame(TEST_STRING, f.get());
}
示例4: testPoll2
import java.util.concurrent.CompletionService; //導入依賴的package包/類
/**
* timed poll returns non-null when the returned task is completed
*/
public void testPoll2()
throws InterruptedException, ExecutionException {
CompletionService cs = new ExecutorCompletionService(cachedThreadPool);
assertNull(cs.poll());
cs.submit(new StringTask());
long startTime = System.nanoTime();
Future f;
while ((f = cs.poll(SHORT_DELAY_MS, MILLISECONDS)) == null) {
if (millisElapsedSince(startTime) > LONG_DELAY_MS)
fail("timed out");
Thread.yield();
}
assertTrue(f.isDone());
assertSame(TEST_STRING, f.get());
}
示例5: testPollReturnsNull
import java.util.concurrent.CompletionService; //導入依賴的package包/類
/**
* poll returns null before the returned task is completed
*/
public void testPollReturnsNull()
throws InterruptedException, ExecutionException {
CompletionService cs = new ExecutorCompletionService(cachedThreadPool);
final CountDownLatch proceed = new CountDownLatch(1);
cs.submit(new Callable() { public String call() throws Exception {
proceed.await();
return TEST_STRING;
}});
assertNull(cs.poll());
assertNull(cs.poll(0L, MILLISECONDS));
assertNull(cs.poll(Long.MIN_VALUE, MILLISECONDS));
long startTime = System.nanoTime();
assertNull(cs.poll(timeoutMillis(), MILLISECONDS));
assertTrue(millisElapsedSince(startTime) >= timeoutMillis());
proceed.countDown();
assertSame(TEST_STRING, cs.take().get());
}
示例6: testTaskAssortment
import java.util.concurrent.CompletionService; //導入依賴的package包/類
/**
* successful and failed tasks are both returned
*/
public void testTaskAssortment()
throws InterruptedException, ExecutionException {
CompletionService cs = new ExecutorCompletionService(cachedThreadPool);
ArithmeticException ex = new ArithmeticException();
for (int i = 0; i < 2; i++) {
cs.submit(new StringTask());
cs.submit(callableThrowing(ex));
cs.submit(runnableThrowing(ex), null);
}
int normalCompletions = 0;
int exceptionalCompletions = 0;
for (int i = 0; i < 3 * 2; i++) {
try {
if (cs.take().get() == TEST_STRING)
normalCompletions++;
}
catch (ExecutionException expected) {
assertTrue(expected.getCause() instanceof ArithmeticException);
exceptionalCompletions++;
}
}
assertEquals(2 * 1, normalCompletions);
assertEquals(2 * 2, exceptionalCompletions);
assertNull(cs.poll());
}
示例7: solveAny
import java.util.concurrent.CompletionService; //導入依賴的package包/類
void solveAny(Executor e,
Collection<Callable<Integer>> solvers)
throws InterruptedException {
CompletionService<Integer> cs
= new ExecutorCompletionService<>(e);
int n = solvers.size();
List<Future<Integer>> futures = new ArrayList<>(n);
Integer result = null;
try {
solvers.forEach((solver) -> futures.add(cs.submit(solver)));
for (int i = n; i > 0; i--) {
try {
Integer r = cs.take().get();
if (r != null) {
result = r;
break;
}
} catch (ExecutionException ignore) {}
}
} finally {
futures.forEach((future) -> future.cancel(true));
}
if (result != null)
use(result);
}
示例8: getFirstToComplete
import java.util.concurrent.CompletionService; //導入依賴的package包/類
private ByteBuffer getFirstToComplete(
CompletionService<ByteBuffer> hedgedService,
ArrayList<Future<ByteBuffer>> futures) throws InterruptedException {
if (futures.isEmpty()) {
throw new InterruptedException("let's retry");
}
Future<ByteBuffer> future = null;
try {
future = hedgedService.take();
ByteBuffer bb = future.get();
futures.remove(future);
return bb;
} catch (ExecutionException | CancellationException e) {
// already logged in the Callable
futures.remove(future);
}
throw new InterruptedException("let's retry");
}
示例9: main
import java.util.concurrent.CompletionService; //導入依賴的package包/類
public static void main(String []args) throws InterruptedException, ExecutionException {
final Random random = new Random();
ExecutorService executorService = Executors.newFixedThreadPool(10);
CompletionService<String>completionService = new ExecutorCompletionService<String>(executorService);
for(int i = 0 ; i < 100 ; i++) {
final int num = i;
completionService.submit(new Callable<String>() {
public String call() {
try {
Thread.sleep((random.nextLong()) & 5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return "num" + num;
}
});
}
for(int i = 0 ; i < 100 ; i++) {
Future<String> f = completionService.take();
System.out.println(f.get());
}
executorService.shutdown();
}
示例10: exec
import java.util.concurrent.CompletionService; //導入依賴的package包/類
/**
* 根據指定的列表關鍵數據及列表數據處理器,並發地處理並返回處理後的列表數據集合
* @param allKeys 列表關鍵數據
* @param handleBizDataFunc 列表數據處理器
* @param <T> 待處理的數據參數類型
* @param <R> 待返回的數據結果類型
* @return 處理後的列表數據集合
*
* NOTE: 類似實現了 stream.par.map 的功能,不帶延遲計算
*/
public static <T,R> List<R> exec(List<T> allKeys, Function<List<T>, List<R>> handleBizDataFunc) {
List<String> parts = TaskUtil.divide(allKeys.size(), TASK_SIZE);
//System.out.println(parts);
CompletionService<List<R>>
completionService = new ExecutorCompletionService<>(executor);
ForeachUtil.foreachDone(parts, (part) -> {
final List<T> tmpRowkeyList = TaskUtil.getSubList(allKeys, part);
completionService.submit(
() -> handleBizDataFunc.apply(tmpRowkeyList)); // lambda replace inner class
});
// foreach code refining
List<R> result = ForeachUtil.foreachAddWithReturn(parts.size(), (ind) -> get(ind, completionService));
return result;
}
示例11: finalizeQueue
import java.util.concurrent.CompletionService; //導入依賴的package包/類
/**
* Removes all task from queue and shuts down executor service.
*
* @param taskQueue Queue of tasks
* @param completionService Producer of new asynchronous tasks
* @param executorService Tasks executor service
*/
public void finalizeQueue(Queue<Future<Void>> taskQueue,
CompletionService<Void> completionService, ExecutorService executorService) {
try {
while (!taskQueue.isEmpty()) {
taskQueue.remove(completionService.take());
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
} finally {
while (!taskQueue.isEmpty()) {
taskQueue.poll().cancel(true);
}
executorService.shutdownNow();
}
}
示例12: getFirstToComplete
import java.util.concurrent.CompletionService; //導入依賴的package包/類
private ByteBuffer getFirstToComplete(
CompletionService<ByteBuffer> hedgedService,
ArrayList<Future<ByteBuffer>> futures) throws InterruptedException {
if (futures.isEmpty()) {
throw new InterruptedException("let's retry");
}
Future<ByteBuffer> future = null;
try {
future = hedgedService.take();
ByteBuffer bb = future.get();
futures.remove(future);
return bb;
} catch (ExecutionException e) {
// already logged in the Callable
futures.remove(future);
} catch (CancellationException ce) {
// already logged in the Callable
futures.remove(future);
}
throw new InterruptedException("let's retry");
}
示例13: addToRequestQueue
import java.util.concurrent.CompletionService; //導入依賴的package包/類
public Boolean addToRequestQueue(JRTServerConfigRequest request, boolean forceResponse, CompletionService<Boolean> completionService) {
// It's no longer delayed if we get here
request.setDelayedResponse(false);
//ConfigDebug.logDebug(log, System.currentTimeMillis(), request.getConfigKey(), "RpcServer.addToRequestQueue()");
try {
final GetConfigProcessor task = new GetConfigProcessor(this, request, forceResponse);
if (completionService == null) {
executorService.submit(task);
} else {
completionService.submit(new Callable<Boolean>() {
@Override
public Boolean call() throws Exception {
task.run();
return true;
}
});
}
updateWorkQueueMetrics();
return true;
} catch (RejectedExecutionException e) {
request.addErrorResponse(ErrorCode.INTERNAL_ERROR, "getConfig request queue size is larger than configured max limit");
respond(request);
return false;
}
}
示例14: trainEachWithEarlyUpdate
import java.util.concurrent.CompletionService; //導入依賴的package包/類
private void trainEachWithEarlyUpdate(Sentence sentence, CompletionService<List<BeamItem>> completionService) {
State.StateIterator iterator = oracle.getState(sentence).getIterator();
State oracleState = iterator.next(); // initial state
List<BeamItem> beam = new ArrayList<>(1);
beam.add(new BeamItem(new State(sentence), 0.0));
boolean terminate = false;
while (!terminate) {
oracleState = iterator.next();
beam = getNextBeamItems(beam, beamWidth, classifier, completionService);
terminate = beam.stream().allMatch(item -> item.getState().isTerminal());
final State finalOracleState = oracleState; // make a variable final to use it in lambda
beam.stream().forEach(item -> {
if (item.getState().equals(finalOracleState)) {
System.out.println("pred.hashCode: " + item.getState().hashCode() + ", oracle.hashCode: " + finalOracleState.hashCode());
}
});
boolean oracleInBeam = beam.stream().anyMatch(item -> item.getState().equals(finalOracleState));;
if (!oracleInBeam || (!terminate && !iterator.hasNext())) {
classifier.update(oracleState, beam.get(0).getState()); // early update
break;
}
}
}
示例15: getNextBeamItems
import java.util.concurrent.CompletionService; //導入依賴的package包/類
public List<BeamItem> getNextBeamItems(List<BeamItem> beam, int beamWidth, Perceptron classifier, CompletionService<List<BeamItem>> completionService) {
try {
List<BeamItem> items1 = BeamSearchDecoder.super.getNextBeamItems(beam, beamWidth, classifier);
List<BeamItem> items2 = BeamSearchDecoder.super.getNextBeamItems(beam, beamWidth, classifier, completionService);
for (int i = 0; i < items1.size(); i++) {
BeamItem item1 = items1.get(i);
BeamItem item2 = items2.get(i);
System.out.println("item1: " + item1.getState() + ": score=" + item1.getScore());
System.out.println("item2: " + item2.getState() + ": score=" + item2.getScore());
if (!item1.equals(item2)) {
throw new Exception(item1 + " != " + item2);
}
}
System.out.println("========");
return items2;
} catch (Exception e) {
throw new RuntimeException(e);
}
}