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


Java LinkedTransferQueue.size方法代碼示例

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


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

示例1: testTransfer2

import java.util.concurrent.LinkedTransferQueue; //導入方法依賴的package包/類
/**
 * transfer waits until a poll occurs. The transfered element
 * is returned by the associated poll.
 */
public void testTransfer2() throws InterruptedException {
    final LinkedTransferQueue<Integer> q = new LinkedTransferQueue<>();
    final CountDownLatch threadStarted = new CountDownLatch(1);

    Thread t = newStartedThread(new CheckedRunnable() {
        public void realRun() throws InterruptedException {
            threadStarted.countDown();
            q.transfer(five);
            checkEmpty(q);
        }});

    threadStarted.await();
    Callable<Boolean> oneElement
        = new Callable<Boolean>() { public Boolean call() {
            return !q.isEmpty() && q.size() == 1; }};
    waitForThreadToEnterWaitState(t, oneElement);

    assertSame(five, q.poll());
    checkEmpty(q);
    awaitTermination(t);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:LinkedTransferQueueTest.java

示例2: testTryTransfer7

import java.util.concurrent.LinkedTransferQueue; //導入方法依賴的package包/類
/**
 * tryTransfer waits for any elements previously in to be removed
 * before transfering to a poll or take
 */
public void testTryTransfer7() throws InterruptedException {
    final LinkedTransferQueue q = new LinkedTransferQueue();
    assertTrue(q.offer(four));

    Thread t = newStartedThread(new CheckedRunnable() {
        public void realRun() throws InterruptedException {
            long startTime = System.nanoTime();
            assertTrue(q.tryTransfer(five, LONG_DELAY_MS, MILLISECONDS));
            assertTrue(millisElapsedSince(startTime) < LONG_DELAY_MS);
            checkEmpty(q);
        }});

    while (q.size() != 2)
        Thread.yield();
    assertEquals(2, q.size());
    assertSame(four, q.poll());
    assertSame(five, q.poll());
    checkEmpty(q);
    awaitTermination(t);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:25,代碼來源:LinkedTransferQueueTest.java

示例3: testTransfer3

import java.util.concurrent.LinkedTransferQueue; //導入方法依賴的package包/類
/**
 * transfer waits until a poll occurs, and then transfers in fifo order
 */
public void testTransfer3() throws InterruptedException {
    final LinkedTransferQueue<Integer> q = new LinkedTransferQueue<>();

    Thread first = newStartedThread(new CheckedRunnable() {
        public void realRun() throws InterruptedException {
            q.transfer(four);
            assertFalse(q.contains(four));
            assertEquals(1, q.size());
        }});

    Thread interruptedThread = newStartedThread(
        new CheckedInterruptedRunnable() {
            public void realRun() throws InterruptedException {
                while (q.isEmpty())
                    Thread.yield();
                q.transfer(five);
            }});

    while (q.size() < 2)
        Thread.yield();
    assertEquals(2, q.size());
    assertSame(four, q.poll());
    first.join();
    assertEquals(1, q.size());
    interruptedThread.interrupt();
    interruptedThread.join();
    checkEmpty(q);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:32,代碼來源:LinkedTransferQueueTest.java

示例4: start

import java.util.concurrent.LinkedTransferQueue; //導入方法依賴的package包/類
@Override
public void start(int numSlots) throws IOException {
  if (!setRunning(true)) {
    return;
  }

  // Init buffer slots
  loading.set(true);
  slots = new ByteSlot[numSlots];
  slotsCache = new LinkedTransferQueue();
  while (slotsCache.size() < numSlots) {
    slotsCache.offer(new ByteSlot());
  }

  // Tunings
  maxRetriesBeforeRoll =
    conf.getInt(MAX_RETRIES_BEFORE_ROLL_CONF_KEY, DEFAULT_MAX_RETRIES_BEFORE_ROLL);
  maxSyncFailureRoll = conf.getInt(MAX_SYNC_FAILURE_ROLL_CONF_KEY, DEFAULT_MAX_SYNC_FAILURE_ROLL);
  waitBeforeRoll = conf.getInt(WAIT_BEFORE_ROLL_CONF_KEY, DEFAULT_WAIT_BEFORE_ROLL);
  rollRetries = conf.getInt(ROLL_RETRIES_CONF_KEY, DEFAULT_ROLL_RETRIES);
  rollThreshold = conf.getLong(ROLL_THRESHOLD_CONF_KEY, DEFAULT_ROLL_THRESHOLD);
  periodicRollMsec = conf.getInt(PERIODIC_ROLL_CONF_KEY, DEFAULT_PERIODIC_ROLL);
  syncWaitMsec = conf.getInt(SYNC_WAIT_MSEC_CONF_KEY, DEFAULT_SYNC_WAIT_MSEC);
  useHsync = conf.getBoolean(USE_HSYNC_CONF_KEY, DEFAULT_USE_HSYNC);

  // Init sync thread
  syncThread = new Thread("WALProcedureStoreSyncThread") {
    @Override
    public void run() {
      try {
        syncLoop();
      } catch (Throwable e) {
        LOG.error("Got an exception from the sync-loop", e);
        if (!isSyncAborted()) {
          sendAbortProcessSignal();
        }
      }
    }
  };
  syncThread.start();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:42,代碼來源:WALProcedureStore.java


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