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


Java Deque.peek方法代碼示例

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


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

示例1: push

import java.util.Deque; //導入方法依賴的package包/類
private void push(String transformerName, String fromUrl, String sourceMimetype, String targetMimetype,
        long sourceSize, TransformationOptions options, Call callType)
{
    Deque<Frame> ourStack = ThreadInfo.getStack();
    Frame frame = ourStack.peek();

    if (callType == Call.TRANSFORM && frame != null && frame.callType == Call.AVAILABLE)
    {
        frame.setTransformerName(transformerName);
        frame.setSourceSize(sourceSize);
        frame.callType = Call.AVAILABLE_AND_TRANSFORM;
    }

    // Create a new frame. Logging level is set to trace if the file size is 0
    boolean origDebugOutput = ThreadInfo.setDebugOutput(ThreadInfo.getDebugOutput() && sourceSize != 0);
    frame = new Frame(frame, transformerName, fromUrl, sourceMimetype, targetMimetype, sourceSize, options, callType, origDebugOutput);
    ourStack.push(frame);
        
    if (callType == Call.TRANSFORM)
    {
        // Log the basic info about this transformation
        logBasicDetails(frame, sourceSize, options.getUse(), transformerName, (ourStack.size() == 1));
    }
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:25,代碼來源:TransformerDebug.java

示例2: unavailableTransformer

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Called to identify a transformer that cannot be used during working out
 * available transformers.
 */
public void unavailableTransformer(ContentTransformer transformer, String sourceMimetype, String targetMimetype, long maxSourceSizeKBytes)
{
    if (isEnabled())
    {
        Deque<Frame> ourStack = ThreadInfo.getStack();
        Frame frame = ourStack.peek();

        if (frame != null)
        {
            Deque<String> isTransformableStack = ThreadInfo.getIsTransformableStack();
            String name = (!isTransformableStack.isEmpty())
                ? isTransformableStack.getFirst()
                : getName(transformer);
            boolean debug = (maxSourceSizeKBytes != 0);
            if (frame.unavailableTransformers == null)
            {
                frame.unavailableTransformers = new TreeSet<UnavailableTransformer>();
            }
            String priority = gePriority(transformer, sourceMimetype, targetMimetype);
            frame.unavailableTransformers.add(new UnavailableTransformer(name, priority, maxSourceSizeKBytes, debug));
        }
    }
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:28,代碼來源:TransformerDebug.java

示例3: solution

import java.util.Deque; //導入方法依賴的package包/類
public int solution(int[] input) {
    int blockCount = 0;

    Deque<Integer> stack = new LinkedList<>();


    for (int height : input) {
        while (stack.size() != 0 && stack.peek() > height) {
            stack.pop();
        }

        if (stack.size() == 0 || stack.peek() != height) {
            blockCount++;
            stack.push(height);
        }
    }

    return blockCount;
}
 
開發者ID:webdude21,項目名稱:codility-solutions,代碼行數:20,代碼來源:Solution.java

示例4: solution

import java.util.Deque; //導入方法依賴的package包/類
public int solution(String input) {
    Deque<Character> stack = new LinkedList<>();

    for (int i = 0; i < input.length(); i++) {
        char currentChar = input.charAt(i);

        if (currentChar == '(') {
            stack.push(currentChar);
        } else if (stack.isEmpty()) {
            return 0;
        } else if (stack.peek() == pairMap.get(currentChar)) {
            stack.pop();
        }
    }

    return stack.isEmpty() ? 1 : 0;
}
 
開發者ID:webdude21,項目名稱:codility-solutions,代碼行數:18,代碼來源:Solution.java

示例5: main

import java.util.Deque; //導入方法依賴的package包/類
public static void main(String[] args) {
    Scanner scann = new Scanner(System.in);
    Deque<Integer> stack = new ArrayDeque<>();
    Deque<Integer> max = new ArrayDeque<>();
    max.push(Integer.MIN_VALUE);
    int comCount = Integer.parseInt(scann.nextLine());
    String[] comm;
    for (int i = 0; i < comCount; i++) {
        comm = scann.nextLine().split("\\s+");
        switch (comm[0]){
            case "1":
                int num = Integer.parseInt(comm[1]);
                stack.push(Integer.parseInt(comm[1]));
                if (num > max.peek()) max.push(num);
                break;
            case "2":
                if(stack.pop() == max.peek()) max.pop();
                break;
            case "3":
                System.out.println(max.peek());
                break;
        }
    }
}
 
開發者ID:kostovhg,項目名稱:SoftUni,代碼行數:25,代碼來源:p02_MaximumElement.java

示例6: maxSlidingWindow

import java.util.Deque; //導入方法依賴的package包/類
public int[] maxSlidingWindow(int[] nums, int k) {
    int len = nums.length;
    if (len == 0) return nums;
    int[] res = new int[len - k + 1];
    
    Deque<Integer> dq = new LinkedList<Integer>();
    for (int i = 0; i < len; i++) {
    	while (!dq.isEmpty() && dq.peekLast() < nums[i])
    		dq.pollLast();
    	
    	dq.offer(nums[i]);
    	
    	if (i >= k - 1) {
    		res[i - k + 1] = dq.peek();
    		if (nums[i - k + 1] == dq.peek())
    			dq.pollFirst();
    	}
    }
	return res;
}
 
開發者ID:JoeZ-EE,項目名稱:Aim2Offer,代碼行數:21,代碼來源:065_MaxInSlidingWindow.java

示例7: getPathFromRoot

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Constructs a path from the root of the document to the given syntax element.
 * 
 * @param element the element to start with
 * @return top-down path of SyntaxElements from the document root towards the original SyntaxElement
 */
public List<SyntaxElement> getPathFromRoot(SyntaxElement element) {
    Deque<SyntaxElement> stack = new ArrayDeque<>();
    SyntaxElement elementRef = element;
    while (elementRef != null) {
        if (isEndTag(element) ||
                (isEmptyTag(elementRef) && stack.isEmpty()) ||
                (isStartTag(elementRef) && stack.isEmpty())) {
            stack.push(elementRef);
            elementRef = elementRef.getPrevious();
            continue;
        }
        if (isStartTag(elementRef)) {
            if (isEndTag(stack.peek())) {
                SyntaxElement end = stack.peek();
                if (end.getNode().getNodeName().equals(elementRef.getNode().getNodeName())) {
                    stack.pop();
                }
            } else {
                SyntaxElement e = stack.peek();
                stack.push(elementRef);
            }
        }
        elementRef = elementRef.getPrevious();
    }
    // reverse:
    List<SyntaxElement> res = new ArrayList<>(stack.size());
    while ((elementRef = stack.poll()) != null) {
        res.add(elementRef);
    }
    return res;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:38,代碼來源:XMLSyntaxSupport.java

示例8: processSplitFlow

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Processes each node in split as a  DSL Flow.
 * @param node represents a single node in the split.
 * @return Deque of Job Flows that was obtained from the Node.
 */
private Deque<Flow> processSplitFlow(LabelledTaskNode node) {
	TaskParser taskParser = new TaskParser("split_flow", node.stringify(),
			false, true);
	ComposedRunnerVisitor splitElementVisitor = new ComposedRunnerVisitor();
	taskParser.parse().accept(splitElementVisitor);

	Deque splitElementDeque = splitElementVisitor.getFlow();
	Deque<Flow> elementFlowDeque = new LinkedList<>();
	Deque<Flow> resultFlowDeque = new LinkedList<>();

	while (!splitElementDeque.isEmpty()) {

		if (splitElementDeque.peek() instanceof TaskAppNode) {

			TaskAppNode taskAppNode = (TaskAppNode) splitElementDeque.pop();

			if (taskAppNode.hasTransitions()) {
				handleTransition(elementFlowDeque, taskAppNode);
			}
			else {
				elementFlowDeque.push(
						getTaskAppFlow(taskAppNode));
			}
		}
		else if (splitElementDeque.peek() instanceof FlowNode) {
			handleFlowForSegment(elementFlowDeque, resultFlowDeque);
			splitElementDeque.pop();
		}
	}

	return resultFlowDeque;
}
 
開發者ID:spring-cloud-task-app-starters,項目名稱:composed-task-runner,代碼行數:38,代碼來源:ComposedRunnerJobFactory.java

示例9: pop

import java.util.Deque; //導入方法依賴的package包/類
private void pop(Call callType, boolean suppressFinish)
{
    Deque<Frame> ourStack = ThreadInfo.getStack();
    if (!ourStack.isEmpty())
    {
        Frame frame = ourStack.peek();

        if ((frame.callType == callType) ||
            (frame.callType == Call.AVAILABLE_AND_TRANSFORM && callType == Call.AVAILABLE))
        {
            int size = ourStack.size();
            String ms = ms(System.currentTimeMillis() - frame.start);

            logInfo(frame, size, ms);
            
            boolean firstLevel = size == 1;
            if (!suppressFinish && (firstLevel || logger.isTraceEnabled()))
            {
                log(FINISHED_IN + ms +
                    (frame.callType == Call.AVAILABLE ? " Transformer NOT called" : "") +
                    (firstLevel ? "\n" : ""), 
                    firstLevel);
            }
            
            setDebugOutput(frame.origDebugOutput);
            ourStack.pop();
        }
    }
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:30,代碼來源:TransformerDebug.java

示例10: debug

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Log a message prefixed with the current transformation reference
 * and include a exception, suppressing the stack trace if repeated
 * as we return up the stack of transformers.
 * @param message
 */
public void debug(String message, Throwable t)
{
    if (isEnabled())
    {
        // Trim messages of the form: "Failed... : \n   reader:...\n    writer:..."
        String msg = t.getMessage();
        if (msg != null)
        {
            int i = msg.indexOf(": \n");
            if (i != -1)
            {
                msg = msg.substring(0, i);
            }
            log(message + ' ' + msg);
        }
        else
        {
            log(message);
        }
        
        
        Deque<Frame> ourStack = ThreadInfo.getStack();
        if (!ourStack.isEmpty())
        {
            Frame frame = ourStack.peek();
            frame.setFailureReason(message +' '+ getRootCauseMessage(t));
        }
    }
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:36,代碼來源:TransformerDebug.java

示例11: current

import java.util.Deque; //導入方法依賴的package包/類
@Nonnull
public static LogContext current() {
    final Deque<LogContext> contextQueue = CONTEXTS.get();
    if (!contextQueue.isEmpty()) {
        return contextQueue.peek();
    } else {
        throw new RuntimeException("Loggable context is absent");
    }
}
 
開發者ID:ivnik,項目名稱:smartlog,代碼行數:10,代碼來源:SmartLog.java

示例12: maxSlidingWindow

import java.util.Deque; //導入方法依賴的package包/類
public static int[] maxSlidingWindow(int[] nums, int k) {
    Deque<Integer> deque = new ArrayDeque<>();
    int n = nums.length;
    int[] res = new int[n - k + 1];
    for (int i = 0; i < n; i++) {
        if (!deque.isEmpty() && deque.peek() == i - k) deque.poll();
        while (!deque.isEmpty() && nums[deque.peekLast()] < nums[i]) deque.pollLast();
        deque.offer(i);
        if (i >= k - 1) {
            res[i + 1 - k] = nums[deque.peek()];
        }
    }
    return res;
}
 
開發者ID:xy1m,項目名稱:PlayGround,代碼行數:15,代碼來源:MaxSlidingWindow.java

示例13: requiresTransitiveGraph

import java.util.Deque; //導入方法依賴的package包/類
/**
 * Returns a Graph containing only requires transitive edges
 * with transitive reduction.
 */
public Graph<String> requiresTransitiveGraph(Configuration cf,
                                             Set<String> roots)
{
    Deque<String> deque = new ArrayDeque<>(roots);
    Set<String> visited = new HashSet<>();
    Graph.Builder<String> builder = new Graph.Builder<>();

    while (deque.peek() != null) {
        String mn = deque.pop();
        if (visited.contains(mn))
            continue;

        visited.add(mn);
        builder.addNode(mn);
        cf.findModule(mn).get()
          .reference().descriptor().requires().stream()
          .filter(d -> d.modifiers().contains(TRANSITIVE)
                            || d.name().equals("java.base"))
          .map(Requires::name)
          .forEach(d -> {
              deque.add(d);
              builder.addEdge(mn, d);
          });
    }

    return builder.build().reduce();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:32,代碼來源:ModuleDotGraph.java

示例14: maxSlidingWindow

import java.util.Deque; //導入方法依賴的package包/類
public int[] maxSlidingWindow(int[] nums, int k) {
    if (k == 0) {
        return new int[0];
    }

    int n = nums.length;

    int[] result = new int[n - k + 1];
    int current = 0;

    Deque<Integer> deque = new ArrayDeque<>();

    for (int i = 0; i < n; i++) {
        while (!deque.isEmpty() && deque.peek() < i - k + 1) {
            deque.poll();
        }

        while(!deque.isEmpty() && nums[deque.peekLast()] < nums[i]) {
            deque.pollLast();
        }

        deque.offer(i);

        if (i >= k - 1) { // allowing sliding window to fit in full initially
            result[current++] = nums[deque.peek()];
        }
    }

    return result;
}
 
開發者ID:viatsko,項目名稱:hack,代碼行數:31,代碼來源:SlidingWindowMaximum.java

示例15: getFunctionType

import java.util.Deque; //導入方法依賴的package包/類
private EnumFunctionType getFunctionType(Token tokend, Deque<Token> deque) throws ParseException
{
    Token token = (Token)deque.peek();

    if (token != null && token.getType() == EnumTokenType.BRACKET_OPEN)
    {
        EnumFunctionType enumfunctiontype1 = EnumFunctionType.parse(token.getText());
        checkNull(enumfunctiontype1, "Unknown function: " + token);
        return enumfunctiontype1;
    }
    else
    {
        EnumFunctionType enumfunctiontype = EnumFunctionType.parse(token.getText());

        if (enumfunctiontype == null)
        {
            return null;
        }
        else if (enumfunctiontype.getCountArguments() > 0)
        {
            throw new ParseException("Missing arguments: " + enumfunctiontype);
        }
        else
        {
            return enumfunctiontype;
        }
    }
}
 
開發者ID:sudofox,項目名稱:Backmemed,代碼行數:29,代碼來源:ExpressionParser.java


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