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


Java Deque.addFirst方法代碼示例

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


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

示例1: findNextLeafNode

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Depth first search, in left-to-right order, of the node tree, using
 * an explicit stack, to find the next non-empty leaf node.
 */
@SuppressWarnings("unchecked")
protected final N findNextLeafNode(Deque<N> stack) {
    N n = null;
    while ((n = stack.pollFirst()) != null) {
        if (n.getChildCount() == 0) {
            if (n.count() > 0)
                return n;
        } else {
            for (int i = n.getChildCount() - 1; i >= 0; i--)
                stack.addFirst((N) n.getChild(i));
        }
    }

    return null;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:20,代碼來源:Nodes.java

示例2: getPath

import java.util.Deque; //導入方法依賴的package包/類
@Override
public final String getPath() {
    FileNaming fileNaming = getFileName();
    Deque<String> stack = new ArrayDeque<String>();
    while (fileNaming != null) {
        stack.addFirst(fileNaming.getName());
        fileNaming = fileNaming.getParent();
    }
    String rootName = stack.removeFirst();
    if (BaseUtilities.isWindows()) {
        rootName = rootName.replace(File.separatorChar, '/');
        if(rootName.startsWith("//")) {  //NOI18N
            // UNC root like //computer/sharedFolder
            rootName += "/";  //NOI18N
        }
    }
    StringBuilder path = new StringBuilder();
    path.append(rootName);
    while (!stack.isEmpty()) {
        path.append(stack.removeFirst());
        if (!stack.isEmpty()) {
            path.append('/');  //NOI18N
        }
    }
    return path.toString();
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:27,代碼來源:BaseFileObj.java

示例3: visitName

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Helper method for import declarations, names, and qualified names.
 */
private void visitName(Tree node) {
    Deque<Name> stack = new ArrayDeque<>();
    for (; node instanceof MemberSelectTree; node = ((MemberSelectTree) node).getExpression()) {
        stack.addFirst(((MemberSelectTree) node).getIdentifier());
    }
    stack.addFirst(((IdentifierTree) node).getName());
    boolean first = true;
    for (Name name : stack) {
        if (!first) {
            token(".");
        }
        token(name.toString());
        first = false;
    }
}
 
開發者ID:tranleduy2000,項目名稱:javaide,代碼行數:19,代碼來源:JavaInputAstVisitor.java

示例4: readEffectiveConfig

import java.util.Deque; //導入方法依賴的package包/類
private static Map<String, Object> readEffectiveConfig(Path filePath){
    Map<String, Object> config = getConfigParametersFromFile(filePath);
    Deque<Map<String, Object>> configs = new ArrayDeque<>();
    configs.add(config);
    while (config.get(INHERIT) != null) {
        String inherit = String.valueOf(config.get(INHERIT));
        filePath = filePath.getParent().resolve(inherit);
        config = getConfigParametersFromFile(filePath);
        if (!config.isEmpty()) {
            configs.addFirst(config);
        }
    }

    Map<String, Object> effectiveConfig = configs.pollFirst();
    while (!configs.isEmpty()) {
        overwriteInnerProperties(effectiveConfig, configs.pollFirst());
    }

    effectiveConfig.remove(INHERIT);

    return effectiveConfig;
}
 
開發者ID:arquillian,項目名稱:smart-testing,代碼行數:23,代碼來源:ConfigurationReader.java

示例5: flatten

import java.util.Deque; //導入方法依賴的package包/類
private synchronized void flatten(final boolean flattenNested) {
    // We use iterative traversal as recursion may exceed the stack size limit.
    final char[] chars = new char[length];
    int pos = length;
    // Strings are most often composed by appending to the end, which causes ConsStrings
    // to be very unbalanced, with mostly single string elements on the right and a long
    // linear list on the left. Traversing from right to left helps to keep the stack small
    // in this scenario.
    final Deque<CharSequence> stack = new ArrayDeque<>();
    stack.addFirst(left);
    CharSequence cs = right;

    do {
        if (cs instanceof ConsString) {
            final ConsString cons = (ConsString) cs;
            // Count the times a cons-string is traversed as part of other cons-strings being flattened.
            // If it crosses a threshold we flatten the nested cons-string internally.
            if (cons.state == STATE_FLATTENED || (flattenNested && ++cons.state >= STATE_THRESHOLD)) {
                cs = cons.flattened(false);
            } else {
                stack.addFirst(cons.left);
                cs = cons.right;
            }
        } else {
            final String str = (String) cs;
            pos -= str.length();
            str.getChars(0, str.length(), chars, pos);
            cs = stack.isEmpty() ? null : stack.pollFirst();
        }
    } while (cs != null);

    left = new String(chars);
    right = "";
    state = STATE_FLATTENED;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:36,代碼來源:ConsString.java

示例6: createPathForRoot

import java.util.Deque; //導入方法依賴的package包/類
private static Deque<FileObject> createPathForRoot(@NonNull FileObject root) {
    final Deque<FileObject> result = new ArrayDeque<>();
    while (root != null) {
        result.addFirst(root);
        root = root.getParent();
    }
    return result;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:9,代碼來源:FileObjectCrawler.java

示例7: testAddFirstOrigin

import java.util.Deque; //導入方法依賴的package包/類
@Test
 public void testAddFirstOrigin() {
     Deque<Integer> queue = new ArrayDeque<Integer>();
     queue.addFirst(1);
     queue.addFirst(2);
     queue.addFirst(3);

     assertThat(queue).containsExactly(3, 2, 1);
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:10,代碼來源:RedissonDequeTest.java

示例8: add

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Add the given request to the queue for the connection it was directed to
 */
public void add(NetworkClient.InFlightRequest request) {
    String destination = request.destination;
    Deque<NetworkClient.InFlightRequest> reqs = this.requests.get(destination);
    if (reqs == null) {
        reqs = new ArrayDeque<>();
        this.requests.put(destination, reqs);
    }
    reqs.addFirst(request);
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:13,代碼來源:InFlightRequests.java

示例9: testUnshift

import java.util.Deque; //導入方法依賴的package包/類
@Test
public void testUnshift() throws ScriptException {
    final Deque<Object> l = getListAdapter();
    l.addFirst(0);
    assertEquals(l.getFirst(), 0);
    assertEquals(l.getLast(), 4);
    assertEquals(l.size(), 5);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:9,代碼來源:AddAndRemoveOnListAdapterOutsideOfJavaScriptContextTest.java

示例10: initStack

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Initiate a stack containing, in left-to-right order, the child nodes
 * covered by this spliterator
 */
@SuppressWarnings("unchecked")
protected final Deque<N> initStack() {
    // Bias size to the case where leaf nodes are close to this node
    // 8 is the minimum initial capacity for the ArrayDeque implementation
    Deque<N> stack = new ArrayDeque<>(8);
    for (int i = curNode.getChildCount() - 1; i >= curChildIndex; i--)
        stack.addFirst((N) curNode.getChild(i));
    return stack;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:14,代碼來源:Nodes.java

示例11: release

import java.util.Deque; //導入方法依賴的package包/類
private void release(DateFormat format, Locale locale)
{
	synchronized( mutex )
	{
		Deque<DateFormat> sp = getSubpool(locale);
		if( sp.size() >= poolSizePerLocale )
		{
			sp.addFirst(format);
		}
	}
}
 
開發者ID:equella,項目名稱:Equella,代碼行數:12,代碼來源:ThreadSafeSimpleDateFormat.java

示例12: examineBuildingsWithSunset

import java.util.Deque; //導入方法依賴的package包/類
public static Deque<BuildingWithHeight> examineBuildingsWithSunset(Iterator<Integer> sequence) {
    Deque<BuildingWithHeight> stack = new ArrayDeque<>();
    int c = 0;
    while (sequence.hasNext()) {
        Integer temp = sequence.next();
        while (stack.peekFirst()!=null && temp >= stack.peekFirst().height) {
            stack.removeFirst();
        }
        stack.addFirst(new BuildingWithHeight(c++,temp));
    }
    return stack;
}
 
開發者ID:gardncl,項目名稱:elements-of-programming-interviews-solutions,代碼行數:13,代碼來源:ComputeBuildingsWithView.java

示例13: pushToWorklist

import java.util.Deque; //導入方法依賴的package包/類
protected static void pushToWorklist(Node expectedNode, Node actualNode, NodeMap<Node> nodeMapping, Deque<Pair<Node, Node>> workList) {
    nodeMapping.set(expectedNode, actualNode);
    if (expectedNode instanceof AbstractEndNode) {
        /* To ensure phi nodes have been added, we handle everything before block ends. */
        workList.addLast(Pair.create(expectedNode, actualNode));
    } else {
        workList.addFirst(Pair.create(expectedNode, actualNode));
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:10,代碼來源:GraphEncoder.java

示例14: toBitArray

import java.util.Deque; //導入方法依賴的package包/類
BitArray toBitArray(byte[] text) {
    Deque<Token> symbols = new LinkedList();
    for (Token token = endBinaryShift(text.length).token; token != null; token = token
            .getPrevious()) {
        symbols.addFirst(token);
    }
    BitArray bitArray = new BitArray();
    for (Token symbol : symbols) {
        symbol.appendTo(bitArray, text);
    }
    return bitArray;
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:13,代碼來源:State.java

示例15: parseTopologyTree

import java.util.Deque; //導入方法依賴的package包/類
protected synchronized void parseTopologyTree() {
  if (machineNodes == null) {
    Node root = getClusterTopology();
    SortedSet<MachineNode> mNodes = new TreeSet<MachineNode>();
    SortedSet<RackNode> rNodes = new TreeSet<RackNode>();
    // dfs search of the tree.
    Deque<Node> unvisited = new ArrayDeque<Node>();
    Deque<Integer> distUnvisited = new ArrayDeque<Integer>();
    unvisited.add(root);
    distUnvisited.add(0);
    for (Node n = unvisited.poll(); n != null; n = unvisited.poll()) {
      int distance = distUnvisited.poll();
      if (n instanceof RackNode) {
        rNodes.add((RackNode) n);
        mNodes.addAll(((RackNode) n).getMachinesInRack());
        if (distance + 1 > maximumDistance) {
          maximumDistance = distance + 1;
        }
      } else if (n instanceof MachineNode) {
        mNodes.add((MachineNode) n);
        if (distance > maximumDistance) {
          maximumDistance = distance;
        }
      } else {
        for (Node child : n.getChildren()) {
          unvisited.addFirst(child);
          distUnvisited.addFirst(distance+1);
        }
      }
    }

    machineNodes = Collections.unmodifiableSortedSet(mNodes);
    rackNodes = Collections.unmodifiableSortedSet(rNodes);
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:36,代碼來源:AbstractClusterStory.java


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