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


Java BlockingQueue.poll方法代碼示例

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


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

示例1: rejectedExecution

import java.util.concurrent.BlockingQueue; //導入方法依賴的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

示例2: rejectedExecution

import java.util.concurrent.BlockingQueue; //導入方法依賴的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

示例3: take

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Override
public E take() throws InterruptedException {
  int startIdx = this.multiplexer.getAndAdvanceCurrentIndex();

  takeLock.lockInterruptibly();
  try {
    // Wait while queue is empty
    for (;;) {
      BlockingQueue<E> q = this.getFirstNonEmptyQueue(startIdx);
      if (q != null) {
        // Got queue, so return if we can poll out an object
        E e = q.poll();
        if (e != null) {
          return e;
        }
      }

      notEmpty.await();
    }
  } finally {
    takeLock.unlock();
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:24,代碼來源:FairCallQueue.java

示例4: postSynchronousMessage

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Override
public <T> T postSynchronousMessage(String taskId, Serializable message, long millis)
{
	String messageId = UUID.randomUUID().toString();
	SimpleMessage msg = new SimpleMessage(messageId, message);
	BlockingQueue<SimpleMessage> blockingQueue = new LinkedBlockingQueue<SimpleMessage>(1);
	messageResponses.put(messageId, blockingQueue);
	processMessage(taskId, msg, true);
	try
	{
		SimpleMessage poll = blockingQueue.poll(millis, TimeUnit.MILLISECONDS);
		if( poll != null )
		{
			return poll.getContents();
		}
		throw new TimeoutException("Timed out waiting for message response");
	}
	catch( InterruptedException e )
	{
		throw new RuntimeException(e);
	}
}
 
開發者ID:equella,項目名稱:Equella,代碼行數:23,代碼來源:LocalTaskServiceImpl.java

示例5: waitForResponse

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
private <T> T waitForResponse(long millis, BlockingQueue<SimpleMessage> blockingQueue)
{
	try
	{
		SimpleMessage poll = blockingQueue.poll(millis, TimeUnit.MILLISECONDS);
		if( poll != null )
		{
			return poll.getContents();
		}
		throw new TimeoutException("Timed out waiting for message response");
	}
	catch( InterruptedException e )
	{
		throw new RuntimeException(e);
	}
}
 
開發者ID:equella,項目名稱:Equella,代碼行數:17,代碼來源:ClusteredTaskServiceImpl.java

示例6: execute

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Override
public JobResult execute(BlockingQueue<String> jobPathArray) {
	String currentThreadName = Thread.currentThread().getName();
	logger.info(" [cz88.net] 線程[" + currentThreadName + "] 爬蟲JOB 開始工作 ");
	JobResult jobResult = new JobResult();
	String url = null  ;
	try {
		while ((url = jobPathArray.poll()) != null) {
			BaseUtil.getInstance().getRedisClient().lpush(Constant.WEBSITE_CODE_QUEUE_CZ88, url) ;
		}
	} catch (Exception e) {
		logger.info("Redis 連接異常 , 網絡是否暢通 , 服務是否啟動") ;
	}
	if (null == url) {
		logger.info(" [cz88.net] 線程[" + currentThreadName + "] 發現隊列為空 停止工作 ");
		CrawlersTaskPool.sharedInstance().getExecutor().shutdown();
	}
	logger.info(" [cz88.net] 線程[" + currentThreadName + "] 爬蟲JOB 結束工作 ");
	return jobResult ;
}
 
開發者ID:m18507308080,項目名稱:bohemia,代碼行數:21,代碼來源:Cz88Job.java

示例7: testDrainTimesOut

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
private void testDrainTimesOut(BlockingQueue<Object> q) throws Exception {
  for (boolean interruptibly : new boolean[] {true, false}) {
    assertEquals(0, Queues.drain(q, ImmutableList.of(), 1, 10, MILLISECONDS));

    Producer producer = new Producer(q, 1);
    // producing one, will ask for two
    Future<?> producerThread = threadPool.submit(producer);
    producer.beganProducing.await();

    // make sure we time out
    Stopwatch timer = Stopwatch.createStarted();

    int drained = drain(q, newArrayList(), 2, 10, MILLISECONDS, interruptibly);
    assertThat(drained).isAtMost(1);

    assertThat(timer.elapsed(MILLISECONDS)).isAtLeast(10L);

    // If even the first one wasn't there, clean up so that the next test doesn't see an element.
    producerThread.cancel(true);
    producer.doneProducing.await();
    if (drained == 0) {
      q.poll(); // not necessarily there if producer was interrupted
    }
  }
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:26,代碼來源:QueuesTest.java

示例8: rejectedExecution

import java.util.concurrent.BlockingQueue; //導入方法依賴的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

示例9: testSamplingError

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Test
public void testSamplingError() {
  KafkaCruiseControlConfig config = new KafkaCruiseControlConfig(getLoadMonitorProperties());
  Metadata metadata = new Metadata();
  MetadataClient metadataClient = new MetadataClient(config, metadata, -1L, TIME);
  MockMetricSampleAggregator mockMetricSampleAggregator = new MockMetricSampleAggregator(config, metadata);
  List<MetricSampler> samplers = new ArrayList<>();
  MetricRegistry dropwizardMetricRegistry = new MetricRegistry();
  for (int i = 0; i < NUM_METRIC_FETCHERS; i++) {
    samplers.add(new MockSampler(i));
  }
  MetricFetcherManager fetcherManager = new MetricFetcherManager(config, mockMetricSampleAggregator, metadataClient,
                                                                 TIME, dropwizardMetricRegistry, samplers);
  LoadMonitorTaskRunner loadMonitorTaskRunner =
      new LoadMonitorTaskRunner(config, fetcherManager, mockMetricSampleAggregator, metadataClient, TIME);
  while (metadata.fetch().topics().size() < 100) {
    metadataClient.refreshMetadata();
  }
  loadMonitorTaskRunner.start(true);

  int numSamples = 0;
  long startMs = System.currentTimeMillis();
  BlockingQueue<PartitionMetricSample> sampleQueue = mockMetricSampleAggregator.metricSampleQueue();
  while (numSamples < (NUM_PARTITIONS * NUM_TOPICS) * 10 && System.currentTimeMillis() < startMs + 10000) {
    PartitionMetricSample sample = sampleQueue.poll();
    if (sample != null) {
      numSamples++;
    }
  }
  // We should have NUM_METRIC_FETCHER rounds of sampling. The first round only has one metric fetcher returns
  // samples, two fetchers return samples for the second round, three for the third and four for the forth round.
  // So the first round only has 1/4 of the total samples, then 2/4, 3/4 and all the samples.
  int expectedNumSamples = 0;
  for (int i = 0; i < NUM_METRIC_FETCHERS; i++) {
    expectedNumSamples += (NUM_TOPICS * NUM_PARTITIONS) * (i + 1) / NUM_METRIC_FETCHERS;
  }
  assertEquals("Only see " + numSamples + " samples. Expecting " + expectedNumSamples + " samples",
      expectedNumSamples, numSamples);
  fetcherManager.shutdown();
}
 
開發者ID:linkedin,項目名稱:cruise-control,代碼行數:41,代碼來源:LoadMonitorTaskRunnerTest.java

示例10: drain

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * Drains the queue as {@link BlockingQueue#drainTo(Collection, int)}, but if the requested
 * {@code numElements} elements are not available, it will wait for them up to the specified
 * timeout.
 *
 * @param q the blocking queue to be drained
 * @param buffer where to add the transferred elements
 * @param numElements the number of elements to be waited for
 * @param timeout how long to wait before giving up, in units of {@code unit}
 * @param unit a {@code TimeUnit} determining how to interpret the timeout parameter
 * @return the number of elements transferred
 * @throws InterruptedException if interrupted while waiting
 */
@Beta
public static <E> int drain(BlockingQueue<E> q, Collection<? super E> buffer, int numElements,
    long timeout, TimeUnit unit) throws InterruptedException {
  Preconditions.checkNotNull(buffer);
  /*
   * This code performs one System.nanoTime() more than necessary, and in return, the time to
   * execute Queue#drainTo is not added *on top* of waiting for the timeout (which could make
   * the timeout arbitrarily inaccurate, given a queue that is slow to drain).
   */
  long deadline = System.nanoTime() + unit.toNanos(timeout);
  int added = 0;
  while (added < numElements) {
    // we could rely solely on #poll, but #drainTo might be more efficient when there are multiple
    // elements already available (e.g. LinkedBlockingQueue#drainTo locks only once)
    added += q.drainTo(buffer, numElements - added);
    if (added < numElements) { // not enough elements immediately available; will have to poll
      E e = q.poll(deadline - System.nanoTime(), TimeUnit.NANOSECONDS);
      if (e == null) {
        break; // we already waited enough, and there are no more elements in sight
      }
      buffer.add(e);
      added++;
    }
  }
  return added;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:40,代碼來源:Queues.java

示例11: drainUninterruptibly

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * Drains the queue as {@linkplain #drain(BlockingQueue, Collection, int, long, TimeUnit)}, 
 * but with a different behavior in case it is interrupted while waiting. In that case, the 
 * operation will continue as usual, and in the end the thread's interruption status will be set 
 * (no {@code InterruptedException} is thrown). 
 * 
 * @param q the blocking queue to be drained
 * @param buffer where to add the transferred elements
 * @param numElements the number of elements to be waited for
 * @param timeout how long to wait before giving up, in units of {@code unit}
 * @param unit a {@code TimeUnit} determining how to interpret the timeout parameter
 * @return the number of elements transferred
 */
@Beta
public static <E> int drainUninterruptibly(BlockingQueue<E> q, Collection<? super E> buffer, 
    int numElements, long timeout, TimeUnit unit) {
  Preconditions.checkNotNull(buffer);
  long deadline = System.nanoTime() + unit.toNanos(timeout);
  int added = 0;
  boolean interrupted = false;
  try {
    while (added < numElements) {
      // we could rely solely on #poll, but #drainTo might be more efficient when there are 
      // multiple elements already available (e.g. LinkedBlockingQueue#drainTo locks only once)
      added += q.drainTo(buffer, numElements - added);
      if (added < numElements) { // not enough elements immediately available; will have to poll
        E e; // written exactly once, by a successful (uninterrupted) invocation of #poll
        while (true) {
          try {
            e = q.poll(deadline - System.nanoTime(), TimeUnit.NANOSECONDS);
            break;
          } catch (InterruptedException ex) {
            interrupted = true; // note interruption and retry
          }
        }
        if (e == null) {
          break; // we already waited enough, and there are no more elements in sight
        }
        buffer.add(e);
        added++;
      }
    }
  } finally {
    if (interrupted) {
      Thread.currentThread().interrupt();
    }
  }
  return added;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:50,代碼來源:Queues.java

示例12: poll

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Override
public E poll(long timeout, TimeUnit unit)
    throws InterruptedException {

  int startIdx = this.multiplexer.getAndAdvanceCurrentIndex();

  long nanos = unit.toNanos(timeout);
  takeLock.lockInterruptibly();
  try {
    for (;;) {
      BlockingQueue<E> q = this.getFirstNonEmptyQueue(startIdx);
      if (q != null) {
        E e = q.poll();
        if (e != null) {
          // Escape condition: there might be something available
          return e;
        }
      }

      if (nanos <= 0) {
        // Wait has elapsed
        return null;
      }

      try {
        // Now wait on the condition for a bit. If we get
        // spuriously awoken we'll re-loop
        nanos = notEmpty.awaitNanos(nanos);
      } catch (InterruptedException ie) {
        notEmpty.signal(); // propagate to a non-interrupted thread
        throw ie;
      }
    }
  } finally {
    takeLock.unlock();
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:38,代碼來源:FairCallQueue.java

示例13: getResult

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * 獲取結果
 * @param blockingQueue
 * @param timeout
 * @param unit
 * @return
 * @throws InterruptedIOException
 */
public static Object getResult(BlockingQueue<Object> blockingQueue,long timeout, TimeUnit unit) throws InterruptedIOException {
    Object result;
    try {
        result = blockingQueue.poll(timeout, unit);
        if (result == null) {
            if (!blockingQueue.offer("")) {
                result = blockingQueue.take();
            }
        }
    } catch (InterruptedException e) {
        throw ExceptionUtil.initCause(new InterruptedIOException(e.getMessage()), e);
    }
    return result;
}
 
開發者ID:DevopsJK,項目名稱:SuitAgent,代碼行數:23,代碼來源:BlockingQueueUtil.java

示例14: poll

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * @return - returns the next Message to be processed out of the queue.
 */
@Override
public Message poll() {
    // If its null, or we hit the end, reset it.
    if (consumerIdIterator == null || !consumerIdIterator.hasNext()) {
        consumerIdIterator = messageBuffer.keySet().iterator();
    }

    // Try every buffer until we hit the end.
    Message returnMsg = null;
    while (returnMsg == null && consumerIdIterator.hasNext()) {

        // Advance iterator
        final VirtualSpoutIdentifier nextConsumerId = consumerIdIterator.next();

        // Find our buffer
        final BlockingQueue<Message> queue = messageBuffer.get(nextConsumerId);

        // We missed?
        if (queue == null) {
            logger.info("Non-existent queue found, resetting iterator.");
            consumerIdIterator = messageBuffer.keySet().iterator();
            continue;
        }
        returnMsg = queue.poll();
    }
    return returnMsg;
}
 
開發者ID:salesforce,項目名稱:storm-dynamic-spout,代碼行數:31,代碼來源:RoundRobinBuffer.java

示例15: getRandomFrameFromVideo

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * Gets a random frame from the video file
 *
 * @param f the video file
 * @return an image frame from the video file
 * @throws Exception if there are any processing errors
 */
private Image getRandomFrameFromVideo(File f) throws Exception {
    BlockingQueue<Image> queue = new DisruptorBlockingQueue<>(MAX_QUEUE_SIZE);
    final VideoLoadedLock videoLoadedLock = new VideoLoadedLock();
    OptionsObject.getInstance().getVideoImportEngine().convertVideoToImages(f, true, queue, videoLoadedLock);
    videoLoadedLock.waitFor();
    return queue.poll();
}
 
開發者ID:KodeMunkie,項目名稱:imagetozxspec,代碼行數:15,代碼來源:WorkManager.java


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