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


Java Queue.peek方法代碼示例

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


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

示例1: width

import java.util.Queue; //導入方法依賴的package包/類
public static int width(TreeNode t) {
    int maxWdith = 0, levelWidth = 0;
    Queue<TreeNode> q = new LinkedList<>();
    q.add(t);
    q.add(null);
    while (!q.isEmpty()) {
        if (null == (t = q.poll())) {
            if (levelWidth > maxWdith)
                maxWdith = levelWidth;
            levelWidth = 0;
            if (null != q.peek()) q.add(null);
        } else {
            levelWidth++;
            if (null != t.getLeft()) q.add(t.getLeft());
            if (null != t.getRight()) q.add(t.getRight());
        }
    }
    return maxWdith;
}
 
開發者ID:ApolloZhu,項目名稱:APCSAB,代碼行數:20,代碼來源:ZhuZhiyu_Period1_BinaryTreeLab.java

示例2: containsTerminal

import java.util.Queue; //導入方法依賴的package包/類
private boolean containsTerminal(Object phrase, List<Terminal> candidates) {
	// cannot contain any terminal node if it is not a nonterminal
	if (!(phrase instanceof Nonterminal))
		return false;

	// Gather all child nodes in 'todo' and check whether one of them is a
	// candidate terminal. If this is the case one of the terminals is
	// part of the phrase.
	Queue<Object> todo = new LinkedList<Object>();
	todo.offer(phrase);
	while (todo.peek() != null) {
		Object top = todo.poll();
		if (candidates.contains(top))
			return true;

		List<Object> children = this.transitions.get(top);
		if (children == null)
			continue;

		for (Object child : children)
			todo.offer(child);
	}

	// default case: no candidate terminal is part of the phrase
	return false;
}
 
開發者ID:artificial-max,項目名稱:polcla,代碼行數:27,代碼來源:ConstituencyTree.java

示例3: query

import java.util.Queue; //導入方法依賴的package包/類
public List<RegistryNode> query(final RegistryFilter filter) {
    List<RegistryNode> matches = new LinkedList<RegistryNode>();
    Queue<RegistryNode> queue = new LinkedList<RegistryNode>();
    
    queue.offer(registryRoot);
    while (queue.peek() != null) {
        final RegistryNode node = queue.poll();
        
        if (filter.accept(node)) {
            matches.add(node);
        }
        
        for (RegistryNode child: node.getChildren()) {
            queue.offer(child);
        }
    }
    
    return matches;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:20,代碼來源:Registry.java

示例4: test

import java.util.Queue; //導入方法依賴的package包/類
@APILevel
final boolean test(Connection connection, Session session, T t) {
	NetCom2Utils.parameterNotNull(connection, session, t);
	final Queue<TriPredicate<Connection, Session, T>> predicateTemp = new LinkedList<>(predicates);
	while (predicateTemp.peek() != null) {
		if (! predicateTemp.remove().test(connection, session, t)) {
			return false;
		}
	}
	return true;
}
 
開發者ID:ThorbenKuck,項目名稱:NetCom2,代碼行數:12,代碼來源:PipelineReceiver.java

示例5: add

import java.util.Queue; //導入方法依賴的package包/類
public void add(final Stock stock){
    final Queue<OhlcContainer> sequence = this.sequences.get(stock.getCode());
    final OhlcContainer latest = sequence.peek();

    if ((latest == null) || (latest.getTime().isBefore(stock.getTime()) && latest.getClose() != stock.getClose())) {
        getLogger().debug("New {} stock {} passed for average processing", stock.getCode(), stock);
        if (sequence.size() == 10)
            sequence.remove();

        sequence.add(stock);

        this.values.replace(stock.getCode(), sequence.stream()
                .mapToDouble(OhlcContainer::getClose)
                .sum() / 10);
    }
}
 
開發者ID:mumukiller,項目名稱:stock-patterns-recognition,代碼行數:17,代碼來源:AverageDirector.java

示例6: poll

import java.util.Queue; //導入方法依賴的package包/類
public Object poll() {
    Object obj = null;
    synchronized (this) {
        Queue<Object> q = this.queue;
        if (q == null) {
        } else {
            obj = q.poll();
            Object ts = this.terminalState;
            if (obj == null && ts != null && q.peek() == null) {
                obj = ts;
                this.terminalState = null;
            }
        }
    }
    return obj;
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:17,代碼來源:RxRingBuffer.java

示例7: peek

import java.util.Queue; //導入方法依賴的package包/類
public Object peek() {
    Object obj;
    synchronized (this) {
        Queue<Object> q = this.queue;
        if (q == null) {
            obj = null;
        } else {
            obj = q.peek();
            Object ts = this.terminalState;
            if (obj == null && ts != null && q.peek() == null) {
                obj = ts;
            }
        }
    }
    return obj;
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:17,代碼來源:RxRingBuffer.java

示例8: constructTreeFromRule

import java.util.Queue; //導入方法依賴的package包/類
private static void constructTreeFromRule(final TreeNode currentNode,
                                          final int currentLevel,
                                          final Queue<InputDriver> inputs,
                                          final DecisionTreeRule rule,
                                          final DecisionTreeType type) {
    final InputDriver value = inputs.poll();

    if (value == null) {
        return;
    }

    TreeNode newNode;
    final int nextLevel = currentLevel + 1;

    if (inputs.peek() == null) {
        newNode = createNode(value, nextLevel, type, NodeSupplier.Type.RESULT, rule);
    } else {
        newNode = createNode(value, nextLevel, type, NodeSupplier.Type.NODE, rule);
    }

    if (currentNode != null) {
        newNode = currentNode.addNode(newNode);
    }

    constructTreeFromRule(newNode, nextLevel, inputs, rule, type);
}
 
開發者ID:jpmorganchase,項目名稱:swblocks-decisiontree,代碼行數:27,代碼來源:DecisionTreeFactory.java

示例9: processNextPending

import java.util.Queue; //導入方法依賴的package包/類
private void processNextPending(final Queue<CommitEntry> queue, final State allowedState,
        final Consumer<CommitEntry> processor) {
    while (!queue.isEmpty()) {
        final CommitEntry entry = queue.peek();
        final SimpleShardDataTreeCohort cohort = entry.cohort;

        if (cohort.isFailed()) {
            LOG.debug("{}: Removing failed transaction {}", logContext, cohort.getIdentifier());
            queue.remove();
            continue;
        }

        if (cohort.getState() == allowedState) {
            processor.accept(entry);
        }

        break;
    }

    maybeRunOperationOnPendingTransactionsComplete();
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:22,代碼來源:ShardDataTree.java

示例10: calculate

import java.util.Queue; //導入方法依賴的package包/類
public DateCalculatorResult calculate(String text) {
    final DateCalcExpressionParser parser = new DateCalcExpressionParser();
    final Queue<Token> tokens = parser.parse(text);

    try {
        if (!tokens.isEmpty()) {
            if (tokens.peek() instanceof DateToken) {
                return handleDateExpression(tokens);
            } else if (tokens.peek() instanceof TimeToken) {
                return handleTimeExpression(tokens);
            }
        }
    } catch (UnsupportedTemporalTypeException utte) {
        throw new DateCalcException(utte.getLocalizedMessage());
    }
    throw new DateCalcException("An invalid expression was given: " + text);
}
 
開發者ID:PacktPublishing,項目名稱:Java-9-Programming-Blueprints,代碼行數:18,代碼來源:DateCalculator.java

示例11: crawl

import java.util.Queue; //導入方法依賴的package包/類
public synchronized Set<NodeRef> crawl(Set<NodeRef> startingNodes)
{
    init();
    Queue<NodeRef> nodesToProcess = new LinkedList<NodeRef>();
    nodesToProcess.addAll(startingNodes);
    Set<NodeRef> resultingNodeSet = new HashSet<NodeRef>(89);
    Set<NodeRef> processedNodes = new HashSet<NodeRef>(89);

    // Do we have any more nodes to process?
    while (nodesToProcess.peek() != null)
    {
        // Yes, we do. Read the next noderef from the queue.
        NodeRef thisNode = nodesToProcess.poll();
        // Check that we haven't already processed it. Skip it if we have, process it if we haven't
        if (!processedNodes.contains(thisNode))
        {
            // Record the fact that we're processing this node
            processedNodes.add(thisNode);
            // We check this node against any filters that are in place (the nodes
            // that we were given to start with are always processed)
            if (startingNodes.contains(thisNode) || includeNode(thisNode))
            {
                resultingNodeSet.add(thisNode);
                Set<NodeRef> subsequentNodes = findSubsequentNodes(thisNode);
                for (NodeRef node : subsequentNodes)
                {
                    nodesToProcess.add(node);
                }
            }
        }
    }
    return resultingNodeSet;
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:34,代碼來源:StandardNodeCrawlerImpl.java

示例12: getNode

import java.util.Queue; //導入方法依賴的package包/類
private TreeNode getNode(Queue<Integer> nodes) {
    if (nodes.isEmpty()) return null;
    Integer val = nodes.poll();
    Queue<Integer> smaller = new LinkedList<>();
    while (!nodes.isEmpty() && nodes.peek() <= val) {
        smaller.offer(nodes.poll());
    }

    TreeNode root = new TreeNode(val);
    root.left = getNode(smaller);
    root.right = getNode(nodes);
    return root;
}
 
開發者ID:xy1m,項目名稱:PlayGround,代碼行數:14,代碼來源:SerializeBinarySearchTree.java

示例13: selectNextStateToProcess

import java.util.Queue; //導入方法依賴的package包/類
/**
 * Picks the cluster state with highest version with the same master from the queue. All cluster states with
 * lower versions are ignored. If a cluster state with a different master is seen the processing logic stops and the
 * last processed state is returned.
 */
static ClusterState selectNextStateToProcess(Queue<ProcessClusterState> processNewClusterStates) {
    // try and get the state with the highest version out of all the ones with the same master node id
    ProcessClusterState stateToProcess = processNewClusterStates.poll();
    if (stateToProcess == null) {
        return null;
    }
    stateToProcess.processed = true;
    while (true) {
        ProcessClusterState potentialState = processNewClusterStates.peek();
        // nothing else in the queue, bail
        if (potentialState == null) {
            break;
        }
        // if its not from the same master, then bail
        if (!Objects.equals(stateToProcess.clusterState.nodes().masterNodeId(), potentialState.clusterState.nodes().masterNodeId())) {
            break;
        }
        // we are going to use it for sure, poll (remove) it
        potentialState = processNewClusterStates.poll();
        if (potentialState == null) {
            // might happen if the queue is drained
            break;
        }
        potentialState.processed = true;

        if (potentialState.clusterState.version() > stateToProcess.clusterState.version()) {
            // we found a new one
            stateToProcess = potentialState;
        }
    }
    return stateToProcess.clusterState;
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:38,代碼來源:ZenDiscovery.java

示例14: handleDateExpression

import java.util.Queue; //導入方法依賴的package包/類
private DateCalculatorResult handleDateExpression(final Queue<Token> tokens) {
    DateToken startDateToken = (DateToken) tokens.poll();
    validateToken(tokens.peek(), OperatorToken.class);
    OperatorToken operatorToken = (OperatorToken) tokens.poll();
    Token thirdToken = tokens.peek();

    if (thirdToken instanceof IntegerToken) {
        return performDateMath(startDateToken, operatorToken, tokens);
    } else if (thirdToken instanceof DateToken) {
        return getDateDiff(startDateToken, tokens.poll());
    } else {
        throw new DateCalcException("Invalid expression");
    }
}
 
開發者ID:PacktPublishing,項目名稱:Java-9-Programming-Blueprints,代碼行數:15,代碼來源:DateCalculator.java

示例15: handleTimeExpression

import java.util.Queue; //導入方法依賴的package包/類
private DateCalculatorResult handleTimeExpression(final Queue<Token> tokens) {
    TimeToken startTimeToken = (TimeToken) tokens.poll();
    validateToken(tokens.peek(), OperatorToken.class);
    OperatorToken operatorToken = (OperatorToken) tokens.poll();
    Token thirdToken = tokens.peek();

    if (thirdToken instanceof IntegerToken) {
        return doTimeMath(operatorToken, startTimeToken, tokens);
    } else if (thirdToken instanceof TimeToken) {
        return getTimeDiff(operatorToken, startTimeToken, tokens.poll());
    } else {
        throw new DateCalcException("Invalid expression");
    }
}
 
開發者ID:PacktPublishing,項目名稱:Java-9-Programming-Blueprints,代碼行數:15,代碼來源:DateCalculator.java


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