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


Java ConcurrentLinkedQueue.poll方法代碼示例

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


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

示例1: takeIdleCon

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
public BackendConnection takeIdleCon(boolean autoCommit) {
	ConcurrentLinkedQueue<BackendConnection> f1 = autoCommitCons;
	ConcurrentLinkedQueue<BackendConnection> f2 = manCommitCons;

	if (!autoCommit) {
		f1 = manCommitCons;
		f2 = autoCommitCons;

	}
	BackendConnection con = f1.poll();
	if (con == null || con.isClosedOrQuit()) {
		con = f2.poll();
	}
	if (con == null || con.isClosedOrQuit()) {
		return null;
	} else {
		return con;
	}

}
 
開發者ID:huang-up,項目名稱:mycat-src-1.6.1-RELEASE,代碼行數:21,代碼來源:ConQueue.java

示例2: longIdleHeartBeat

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
/**
 * check if the connection is not be used for a while & do connection heart beat
 *
 * @param linkedQueue
 * @param hearBeatTime
 */
private void longIdleHeartBeat(ConcurrentLinkedQueue<BackendConnection> linkedQueue, long hearBeatTime) {
    long length = linkedQueue.size();
    for (int i = 0; i < length; i++) {
        BackendConnection con = linkedQueue.poll();
        if (con.isClosedOrQuit()) {
            continue;
        } else if (con.getLastTime() < hearBeatTime) { //if the connection is idle for a long time
            con.setBorrowed(true);
            new ConnectionHeartBeatHandler().doHeartBeat(con);
        } else {
            linkedQueue.offer(con);
            break;
        }
    }
}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:22,代碼來源:PhysicalDatasource.java

示例3: takeIdleCon

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
public BackendConnection takeIdleCon(boolean autoCommit) {
    ConcurrentLinkedQueue<BackendConnection> f1 = autoCommitCons;
    ConcurrentLinkedQueue<BackendConnection> f2 = manCommitCons;

    if (!autoCommit) {
        f1 = manCommitCons;
        f2 = autoCommitCons;

    }
    BackendConnection con = f1.poll();
    if (con == null || con.isClosedOrQuit()) {
        con = f2.poll();
    }
    if (con == null || con.isClosedOrQuit()) {
        return null;
    } else {
        return con;
    }

}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:21,代碼來源:ConQueue.java

示例4: cascadeExecuteCachedTransaction

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
public void cascadeExecuteCachedTransaction(TransactionId pTrxId,boolean trxStatus){
	ConcurrentLinkedQueue<LogProcessContext> queue = compensationLogContextCache.getIfPresent(pTrxId);
	if(queue == null) {
		return ;
	}
	
	for(LogProcessContext logContext = queue.poll(); logContext != null; logContext = queue.poll()){
		compensationLogContextCache.invalidate(pTrxId);
		logContext.setFinalMasterTransStatus(trxStatus);
		//asynchronous execute to enhance efficient
		executor.execute(getRunnableCompensation(logContext));
	}
}
 
開發者ID:QNJR-GROUP,項目名稱:EasyTransaction,代碼行數:14,代碼來源:EasyTransSynchronizer.java

示例5: toHandle

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
public List<JTextComponent> toHandle(ConcurrentLinkedQueue<JTextComponent> q) {
    List<JTextComponent> rs = new LinkedList<JTextComponent>();
    JTextComponent tx;
    while((tx = q.poll()) != null) {
        rs.add(tx);
    }
    return rs;            
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:9,代碼來源:UndoRedoSupport.java

示例6: testConcurrency_MultiInstance_Ordering

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
@Test
public void testConcurrency_MultiInstance_Ordering() throws InterruptedException {
    final ConcurrentLinkedQueue<Thread> queue = new ConcurrentLinkedQueue<>();
    final AtomicInteger lockedCounter = new AtomicInteger();

    int totalThreads = Runtime.getRuntime().availableProcessors()*2;
    for (int i = 0; i < totalThreads; i++) {
        Thread t1 = new Thread(() -> {
            Lock lock = redisson.getFairLock("testConcurrency_MultiInstance2");
            queue.add(Thread.currentThread());
            lock.lock();
            Thread t = queue.poll();
            assertThat(t).isEqualTo(Thread.currentThread());
            try {
                Thread.sleep(1000);
            } catch (Exception e) {
                e.printStackTrace();
            }
            lockedCounter.incrementAndGet();
            lock.unlock();
        });
        Thread.sleep(10);
        t1.start();
    }
    
    await().atMost(30, TimeUnit.SECONDS).until(() -> assertThat(lockedCounter.get()).isEqualTo(totalThreads));
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:28,代碼來源:RedissonFairLockTest.java

示例7: fetchQueue

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
private String fetchQueue(ConcurrentLinkedQueue<String> queue, int maxtime) {
    StringBuilder resultString = new StringBuilder();
    Long startTime = DateTimeHelper.getCurrentTime();

    if (queue.peek() == null) {
        return "";
    }

    String queueString = "";
    while (true) {
        queueString = queue.poll();
        if (queueString != null) {
            if (queueString.trim().length() > 0) {
                resultString.append(queueString + "\n");
            }
        } else {
            try {
                Thread.sleep(10);
            } catch (Exception e) {
                //log.error(e.getMessage());
            }
        }

        if ((DateTimeHelper.getCurrentTime() - startTime) > maxtime || resultString.length() > processMaxCount) {
            break;
        }
    }

    return resultString.toString();
}
 
開發者ID:weiboad,項目名稱:fiery,代碼行數:31,代碼來源:CurlThread.java

示例8: testContains

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
/**
 * contains(x) reports true when elements added but not yet removed
 */
public void testContains() {
    ConcurrentLinkedQueue q = populatedQueue(SIZE);
    for (int i = 0; i < SIZE; ++i) {
        assertTrue(q.contains(new Integer(i)));
        q.poll();
        assertFalse(q.contains(new Integer(i)));
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:12,代碼來源:ConcurrentLinkedQueueTest.java

示例9: takeIdleCon

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
public RedisBackendConnection takeIdleCon() {		
	ConcurrentLinkedQueue<RedisBackendConnection> f1 = cons;
	RedisBackendConnection con = f1.poll();
	if (con == null || con.isClosed() || !con.isConnected() ) {
		return null;
	} else {
		return con;
	}
}
 
開發者ID:variflight,項目名稱:feeyo-redisproxy,代碼行數:10,代碼來源:ConQueue.java

示例10: cleanup

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
private static void cleanup(ConcurrentLinkedQueue<byte[]> q)
{
	if (q != null)
		while (q.poll() != null)
		{
			//pooledCount.decrementAndGet();
		}
}
 
開發者ID:bp2008,項目名稱:blueirisviewer,代碼行數:9,代碼來源:ByteArrayPool.java

示例11: testCacheMultiThreaded

import java.util.concurrent.ConcurrentLinkedQueue; //導入方法依賴的package包/類
public static void testCacheMultiThreaded(final BlockCache toBeTested,
    final int blockSize, final int numThreads, final int numQueries,
    final double passingScore) throws Exception {

  Configuration conf = new Configuration();
  MultithreadedTestUtil.TestContext ctx = new MultithreadedTestUtil.TestContext(
      conf);

  final AtomicInteger totalQueries = new AtomicInteger();
  final ConcurrentLinkedQueue<HFileBlockPair> blocksToTest = new ConcurrentLinkedQueue<HFileBlockPair>();
  final AtomicInteger hits = new AtomicInteger();
  final AtomicInteger miss = new AtomicInteger();

  HFileBlockPair[] blocks = generateHFileBlocks(numQueries, blockSize);
  blocksToTest.addAll(Arrays.asList(blocks));

  for (int i = 0; i < numThreads; i++) {
    TestThread t = new MultithreadedTestUtil.RepeatingTestThread(ctx) {
      @Override
      public void doAnAction() throws Exception {
        if (!blocksToTest.isEmpty()) {
          HFileBlockPair ourBlock = blocksToTest.poll();
          // if we run out of blocks to test, then we should stop the tests.
          if (ourBlock == null) {
            ctx.setStopFlag(true);
            return;
          }
          toBeTested.cacheBlock(ourBlock.blockName, ourBlock.block);
          Cacheable retrievedBlock = toBeTested.getBlock(ourBlock.blockName,
              false, false, true);
          if (retrievedBlock != null) {
            assertEquals(ourBlock.block, retrievedBlock);
            toBeTested.evictBlock(ourBlock.blockName);
            hits.incrementAndGet();
            assertNull(toBeTested.getBlock(ourBlock.blockName, false, false, true));
          } else {
            miss.incrementAndGet();
          }
          totalQueries.incrementAndGet();
        }
      }
    };
    t.setDaemon(true);
    ctx.addThread(t);
  }
  ctx.startThreads();
  while (!blocksToTest.isEmpty() && ctx.shouldRun()) {
    Thread.sleep(10);
  }
  ctx.stop();
  if (hits.get() / ((double) hits.get() + (double) miss.get()) < passingScore) {
    fail("Too many nulls returned. Hits: " + hits.get() + " Misses: "
        + miss.get());
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:56,代碼來源:CacheTestUtils.java


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