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


Java Queue.offer方法代碼示例

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


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

示例1: 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

示例2: free

import java.util.Queue; //導入方法依賴的package包/類
private void free(ByteBuffer oldBuf) {
    if ((oldBuf == null) || ((maxCachedBufferSize != 0) && (oldBuf.capacity() > maxCachedBufferSize))
            || oldBuf.isReadOnly() || isDerived() || (Thread.currentThread() != ownerThread)) {
        return;
    }

    // Add to the cache.
    Queue<CachedBuffer> pool;

    if (oldBuf.isDirect()) {
        pool = directBuffers.get().get(oldBuf.capacity());
    } else {
        pool = heapBuffers.get().get(oldBuf.capacity());
    }

    if (pool == null) {
        return;
    }

    // Restrict the size of the pool to prevent OOM.
    if ((maxPoolSize == 0) || (pool.size() < maxPoolSize)) {
        pool.offer(new CachedBuffer(oldBuf));
    }
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:25,代碼來源:CachedBufferAllocator.java

示例3: getImportance

import java.util.Queue; //導入方法依賴的package包/類
public int getImportance(List<Employee> employees, int id) {
    final int[] sum = {0};
    Queue<Integer> q = new LinkedList<>();
    q.offer(id);
    while (!q.isEmpty()) {
        int i = q.poll();
        Employee e = find(employees, i);
        if (e != null) {
            sum[0] += e.importance;
            List<Integer> sub = e.subordinates;
            if (!sub.isEmpty()) {
                sub.forEach(s -> {
                    Employee emp = find(employees, s);
                    if (emp != null) {
                        q.offer(emp.id);
                    }
                });
            }
        }
    }
    return sum[0];
}
 
開發者ID:bakhodirsbox,項目名稱:AlgoCS,代碼行數:23,代碼來源:EmployeeImp_690.java

示例4: rightSideView

import java.util.Queue; //導入方法依賴的package包/類
public List<Integer> rightSideView(TreeNode root) {
    if (root == null) return new LinkedList<>();
    Queue<TreeNode> q = new LinkedList<>();
    List<Integer> l = new LinkedList<>();
    q.offer(root);
    while (!q.isEmpty()) {
        int size = q.size();
        for (int i = 0; i < size; i++) {
            TreeNode t = q.poll();
            if (i == 0) l.add(t.val);
            if (t.right != null) {
                q.offer(t.right);
            }
            if (t.left != null) {
                q.offer(t.left);
            }
        }
    }
    return l;
}
 
開發者ID:bakhodirsbox,項目名稱:AlgoCS,代碼行數:21,代碼來源:BinTreeRightSide_199.java

示例5: largestValues

import java.util.Queue; //導入方法依賴的package包/類
public List<Integer> largestValues(TreeNode root) {
    if (root == null) return new LinkedList<>();
    List<Integer> maxs = new LinkedList<>();
    Queue<TreeNode> q = new LinkedList<>();
    q.offer(root);
    int max = Integer.MIN_VALUE;
    while (!q.isEmpty()) {
        int size = q.size();
        for (int i = 0; i < size; i++) {
            TreeNode t = q.poll();
            if (t.val > max) max = t.val;
            if (t.left != null) q.offer(t.left);
            if (t.right != null) q.offer(t.right);
        }
        maxs.add(max);
        max = Integer.MIN_VALUE;
    }
    return maxs;
}
 
開發者ID:bakhodirsbox,項目名稱:AlgoCS,代碼行數:20,代碼來源:LargeValEachRow_515.java

示例6: setRoadTrafficNotInNavigate

import java.util.Queue; //導入方法依賴的package包/類
/**
 * 檢查路書是否堵車
 *
 * @param target     目標地點
 * @param routeModel 路書
 * @param sb         路況信息
 * @return true=是
 */
private boolean setRoadTrafficNotInNavigate(String target, RouteModel routeModel, StringBuilder sb) {
    routeModel.refreshRoadCondition();
    Log.i(TAG, "conditionNodes.size=" + routeModel.getConditionNodes().size());
    Queue<Integer> rQueue = new LinkedBlockingQueue<Integer>();
    int conjestionCount = 0;
    for (int i = 0; i < routeModel.getConditionNodes().size(); ++i) {
        if (routeModel.getConditionNodes().get(i).getRoadCondition() >= RouteModel.ROAD_CONDITION_TYPE_Slow) {
            rQueue.offer(i);
            if (routeModel.getConditionNodes().get(i).getRoadCondition() > RouteModel.ROAD_CONDITION_TYPE_Slow) {
                conjestionCount++;
            }
        }
    }
    return setTrafficState(sb, routeModel, rQueue, conjestionCount, 0);
}
 
開發者ID:LingjuAI,項目名稱:AssistantBySDK,代碼行數:24,代碼來源:NavigatorService.java

示例7: processGrouperTypeToken

import java.util.Queue; //導入方法依賴的package包/類
private void processGrouperTypeToken(
		final Queue<Token> outputQueue,
		final Deque<Token> operationStack,
		final Token token ) {
	final GrouperType grouperType = (GrouperType) token.getValue();
	if ( grouperType == GrouperType.LEFT_PARENTHESES ) {
		operationStack.push( token );
		return;
	}
	checkArgument( grouperType == GrouperType.RIGHT_PARENTHESES );
	boolean foundLeftParentheses = false;
	for ( final Iterator<Token> tokenIterator = operationStack.iterator(); tokenIterator
			.hasNext(); ) {
		final Token stackedOperationToken = tokenIterator.next();
		if ( isLeftParentheses( stackedOperationToken ) ) {
			foundLeftParentheses = true;
			tokenIterator.remove();
			break;
		}
		tokenIterator.remove();
		outputQueue.offer( stackedOperationToken );
	}
	if ( ! foundLeftParentheses ) {
		throw new SyntaxExpressionException(
				"Mismatched right parentheses." );
	}
}
 
開發者ID:WellCosta,項目名稱:MathMax,代碼行數:28,代碼來源:Parser.java

示例8: getUsedNamespaces

import java.util.Queue; //導入方法依賴的package包/類
/**
 * Iterates through policy vocabulary and extracts set of namespaces used in
 * the policy expression.
 *
 * @return collection of used namespaces within given policy instance
 * @throws PolicyException Thrown if internal processing failed.
 */
private Collection<String> getUsedNamespaces() throws PolicyException {
    final Set<String> namespaces = new HashSet<String>();
    namespaces.add(getNamespaceVersion().toString());

    if (this.policyId != null) {
        namespaces.add(PolicyConstants.WSU_NAMESPACE_URI);
    }

    final Queue<ModelNode> nodesToBeProcessed = new LinkedList<ModelNode>();
    nodesToBeProcessed.add(rootNode);

    ModelNode processedNode;
    while ((processedNode = nodesToBeProcessed.poll()) != null) {
        for (ModelNode child : processedNode.getChildren()) {
            if (child.hasChildren()) {
                if (!nodesToBeProcessed.offer(child)) {
                    throw LOGGER.logSevereException(new PolicyException(LocalizationMessages.WSP_0081_UNABLE_TO_INSERT_CHILD(nodesToBeProcessed, child)));
                }
            }

            if (child.isDomainSpecific()) {
                final AssertionData nodeData = child.getNodeData();
                namespaces.add(nodeData.getName().getNamespaceURI());
                if (nodeData.isPrivateAttributeSet()) {
                    namespaces.add(PolicyConstants.SUN_POLICY_NAMESPACE_URI);
                }

                for (Entry<QName, String> attribute : nodeData.getAttributesSet()) {
                    namespaces.add(attribute.getKey().getNamespaceURI());
                }
            }
        }
    }

    return namespaces;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:44,代碼來源:PolicySourceModel.java

示例9: main

import java.util.Queue; //導入方法依賴的package包/類
public static void main(String[] args) {
    Queue<Long> userIds = new ArrayDeque<>();
    userIds.offer(1l);

    for (int i = 0; userIds.iterator().hasNext(); i++) {
        final long nextUserId = userIds.iterator().next();
        System.out.println(i + ":" + nextUserId);
    }

}
 
開發者ID:freedompy,項目名稱:commelina,代碼行數:11,代碼來源:ArrayTest.java

示例10: 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

示例11: createPropertyEvaluator

import java.util.Queue; //導入方法依賴的package包/類
/**
 * Creates a {@link PropertyEvaluator} with {@link ProjectConfiguration} support.
 * @param project the project to create {@link PropertyEvaluator} for
 * @param helper the {@link Project}'s {@link AntProjectHelper}
 * @param additionalPropertyProviders the additional {@link PropertyProvider}s
 * @return a new {@link PropertyEvaluator}
 */
@NonNull
public static PropertyEvaluator createPropertyEvaluator(
    @NonNull final Project project,
    @NonNull final AntProjectHelper helper,
    @NonNull final PropertyProvider... additionalPropertyProviders) {
    Parameters.notNull("project", project); //NOI18N
    Parameters.notNull("helper", helper);   //NOI18N
    Parameters.notNull("additionalPropertyProviders", additionalPropertyProviders); //NOI18N

    PropertyEvaluator baseEval1 = PropertyUtils.sequentialPropertyEvaluator(
            helper.getStockPropertyPreprovider(),
            helper.getPropertyProvider(ProjectConfigurations.CONFIG_PROPS_PATH));
    PropertyEvaluator baseEval2 = PropertyUtils.sequentialPropertyEvaluator(
            helper.getStockPropertyPreprovider(),
            helper.getPropertyProvider(AntProjectHelper.PRIVATE_PROPERTIES_PATH));
    final Queue<PropertyProvider> providers = new ArrayDeque<>(additionalPropertyProviders.length + 7);
    providers.offer(helper.getPropertyProvider(ProjectConfigurations.CONFIG_PROPS_PATH));
    providers.offer(new ConfigPropertyProvider(baseEval1, "nbproject/private/configs", helper));    //NOI18N
    providers.offer(helper.getPropertyProvider(AntProjectHelper.PRIVATE_PROPERTIES_PATH));
    providers.offer(helper.getProjectLibrariesPropertyProvider());
    providers.offer(PropertyUtils.userPropertiesProvider(baseEval2,
        "user.properties.file", FileUtil.toFile(project.getProjectDirectory())));   //NOI18N
    providers.offer(new ConfigPropertyProvider(baseEval1, "nbproject/configs", helper));    //NOI18N
    providers.offer(helper.getPropertyProvider(AntProjectHelper.PROJECT_PROPERTIES_PATH));
    Collections.addAll(providers, additionalPropertyProviders);
    return PropertyUtils.sequentialPropertyEvaluator(
        helper.getStockPropertyPreprovider(),
        providers.toArray(new PropertyProvider[providers.size()]));
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:37,代碼來源:ProjectConfigurations.java

示例12: main

import java.util.Queue; //導入方法依賴的package包/類
public static void main(String[] args) {
	
	//LinkedList é uma fila também, por isso sua participação na definição
	Queue<String> fila = new LinkedList<>();
	
	//offer trabalha como o add
	//Sua diferença é que quando, por qualquer motivo, não seja possível inserir ele não vai retornar erro
	//simplesmente ele irá retornar falso
	fila.offer("Maria");
	fila.offer("João");
	
	fila.add("José"); // -> Retorna erro
	
	//Os dois métodos Peek/Element pegam elementos da lista, porém
	//Peek -> Quando a fila está vazia retorna null
	//Element -> Quando a fila está vazia retorna um erro
	
	System.out.println("Peek/Element...");
	
	System.out.println(fila.peek());
	System.out.println(fila.element());
	
	//Removendo elementos da lista
	//Poll/Remove...
	System.out.println("Pool/Remove");
	System.out.println(fila.poll()); //-> Remove o primeiro da fila
	System.out.print(fila.remove());
	System.out.println(fila.poll());
	System.out.println(fila.poll()); //Quando os elementos da fila acabam e o poll é executado
									 //ele retorna null
	
	System.out.println(fila.remove()); //Quando os elementos da fila acabam e o remove é executado
										//ele retorna um erro

	
}
 
開發者ID:Gigers,項目名稱:Examples,代碼行數:37,代碼來源:Fila.java

示例13: forceClearLocks

import java.util.Queue; //導入方法依賴的package包/類
Collection<? extends Lock> forceClearLocks() {
    synchronized (locks) {
        final Queue<RecordOwnerLock> locked = new ArrayDeque<>();
        for (Iterator<RecordOwnerLock> it = locks.values().iterator();
            it.hasNext();) {
            RecordOwnerLock lock = it.next();
            if (lock.isLocked()) {
                it.remove();
                locked.offer(lock);
            }
        }
        return locked;
    }
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:15,代碼來源:RecordOwnerLockFactory.java

示例14: travelBFS

import java.util.Queue; //導入方法依賴的package包/類
/**
 * Benedth First Search
 */
@Override
public LinkedList<StationGraphVO> travelBFS(StationGraphVO vertex, boolean isAscending) {
	LinkedList<StationGraphVO> results = new LinkedList<>();
	
	HashSet<StationGraphVO> checkVisitSet = new HashSet<>();
	
	Queue<StationGraphVO> queue = new LinkedList<>();
	
	//첫 번째 Node 방문
	StationGraphVO firstVertex = getVertex(vertex);
	queue.offer(firstVertex);
	checkVisitSet.add(firstVertex);
	
	while(!queue.isEmpty()) {
		StationGraphVO dequeuedVertex = queue.poll();
		results.add(dequeuedVertex);
		
		sort(edgesByVertices.get(dequeuedVertex), isAscending);
		
		for(Edge edge : edgesByVertices.get(dequeuedVertex)) {
			
			StationGraphVO linkedVertex = edge.getToVertex();
			linkedVertex = edgesByVertices.ceilingKey(linkedVertex); //추가
			
			if(!checkVisitSet.contains(linkedVertex)) {
				checkVisitSet.add(linkedVertex);
				queue.offer(linkedVertex);
			}
		}
	}
	
	return results;
}
 
開發者ID:xeyez,項目名稱:StationGraph,代碼行數:37,代碼來源:StationGraph.java

示例15: bfs

import java.util.Queue; //導入方法依賴的package包/類
/**
 * BFS the merge tree and identify cluster membership.
 * @param membership the cluster membership array.
 * @param cluster the last merge point of cluster.
 * @param id the cluster ID.
 */
private void bfs(int[] membership, int cluster, int id) {
    int n = merge.length + 1;
    Queue<Integer> queue = new LinkedList<>();
    queue.offer(cluster);

    for (Integer i = queue.poll(); i != null; i = queue.poll()) {
        if (i < n) {
            membership[i] = id;
            continue;
        }

        i -= n;

        int m1 = merge[i][0];

        if (m1 >= n) {
            queue.offer(m1);
        } else {
            membership[m1] = id;
        }

        int m2 = merge[i][1];

        if (m2 >= n) {
            queue.offer(m2);
        } else {
            membership[m2] = id;
        }
    }
}
 
開發者ID:takun2s,項目名稱:smile_1.5.0_java7,代碼行數:37,代碼來源:HierarchicalClustering.java


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