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


Java Collections.rotate方法代碼示例

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


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

示例1: reorderBySourcePosition

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Rotate the list of dimension specifiers until all dimensions with type annotations appear in
 * source order.
 * <p>
 * <p>javac reorders dimension specifiers in method declarations with mixed-array notation, which
 * means that any type annotations don't appear in source order.
 * <p>
 * <p>For example, the type of {@code int @A [] f() @B [] {}} is parsed as {@code @B [] @A []}.
 * <p>
 * <p>This doesn't handle cases with un-annotated dimension specifiers, so the formatting logic
 * checks the token stream to figure out which side of the method name they appear on.
 */
private static Iterable<List<AnnotationTree>> reorderBySourcePosition(
        Deque<List<AnnotationTree>> dims) {
    int lastAnnotation = -1;
    int lastPos = -1;
    int idx = 0;
    for (List<AnnotationTree> dim : dims) {
        if (!dim.isEmpty()) {
            int pos = ((JCTree) dim.get(0)).getStartPosition();
            if (pos < lastPos) {
                List<List<AnnotationTree>> list = new ArrayList<>(dims);
                Collections.rotate(list, -(lastAnnotation + 1));
                return list;
            }
            lastPos = pos;
            lastAnnotation = idx;
        }
        idx++;
    }
    return dims;
}
 
開發者ID:tranleduy2000,項目名稱:javaide,代碼行數:33,代碼來源:DimensionHelpers.java

示例2: moveAlgorithmAtIndex

import java.util.Collections; //導入方法依賴的package包/類
public void moveAlgorithmAtIndex(int sourcePosition, int targetPosition)
{
	logger.debug("Shifting algorithm in list. Source=" + sourcePosition + ", Target=" + targetPosition);
	if (sourcePosition <= targetPosition) 
	{
		Collections.rotate(this.algorithmList.subList(sourcePosition, targetPosition + 1), -1);
	} 
	else 
	{
		Collections.rotate(this.algorithmList.subList(targetPosition, sourcePosition + 1), 1);
	}
}
 
開發者ID:scriptkittie,項目名稱:GlitchKernel,代碼行數:13,代碼來源:GlitchController.java

示例3: nextHost

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Returns an {@link Iterable} of hosts to be used for a request call.
 * Ideally, the first host is retrieved from the iterable and used successfully for the request.
 * Otherwise, after each failure the next host has to be retrieved from the iterator so that the request can be retried until
 * there are no more hosts available to retry against. The maximum total of attempts is equal to the number of hosts in the iterable.
 * The iterator returned will never be empty. In case there are no healthy hosts available, or dead ones to be be retried,
 * one dead host gets returned so that it can be retried.
 */
private HostTuple<Iterator<HttpHost>> nextHost() {
    final HostTuple<Set<HttpHost>> hostTuple = this.hostTuple;
    Collection<HttpHost> nextHosts = Collections.emptySet();
    do {
        Set<HttpHost> filteredHosts = new HashSet<>(hostTuple.hosts);
        for (Map.Entry<HttpHost, DeadHostState> entry : blacklist.entrySet()) {
            if (System.nanoTime() - entry.getValue().getDeadUntilNanos() < 0) {
                filteredHosts.remove(entry.getKey());
            }
        }
        if (filteredHosts.isEmpty()) {
            //last resort: if there are no good host to use, return a single dead one, the one that's closest to being retried
            List<Map.Entry<HttpHost, DeadHostState>> sortedHosts = new ArrayList<>(blacklist.entrySet());
            if (sortedHosts.size() > 0) {
                Collections.sort(sortedHosts, new Comparator<Map.Entry<HttpHost, DeadHostState>>() {
                    @Override
                    public int compare(Map.Entry<HttpHost, DeadHostState> o1, Map.Entry<HttpHost, DeadHostState> o2) {
                        return Long.compare(o1.getValue().getDeadUntilNanos(), o2.getValue().getDeadUntilNanos());
                    }
                });
                HttpHost deadHost = sortedHosts.get(0).getKey();
                logger.trace("resurrecting host [" + deadHost + "]");
                nextHosts = Collections.singleton(deadHost);
            }
        } else {
            List<HttpHost> rotatedHosts = new ArrayList<>(filteredHosts);
            Collections.rotate(rotatedHosts, rotatedHosts.size() - lastHostIndex.getAndIncrement());
            nextHosts = rotatedHosts;
        }
    } while(nextHosts.isEmpty());
    return new HostTuple<>(nextHosts.iterator(), hostTuple.authCache);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:41,代碼來源:RestClient.java

示例4: SortAndAnimate

import java.util.Collections; //導入方法依賴的package包/類
/**
 * @param sortByDate true to sort bookmarks by date false to sort them by position in the book
 */
public void SortAndAnimate(boolean sortByDate) {
    Bookmark.sortByDate = sortByDate;
    for (int i = 1; i < bookmarkList.size(); i++) {
        int j = Math.abs(Collections.binarySearch(bookmarkList.subList(0, i), bookmarkList.get(i)) + 1);
        Collections.rotate(bookmarkList.subList(j, i + 1), j - i);
        notifyItemMoved(i, j);
    }
}
 
開發者ID:fekracomputers,項目名稱:IslamicLibraryAndroid,代碼行數:12,代碼來源:BookmarkRecyclerViewAdapter.java

示例5: SortAndAnimate

import java.util.Collections; //導入方法依賴的package包/類
/**
 * @param sortByDate true to sort highlights by date false to sort them by position in the book
 */
public void SortAndAnimate(boolean sortByDate) {
    Highlight.sortByDate = sortByDate;
    for (int i = 1; i < highlightList.size(); i++) {
        int j = Math.abs(Collections.binarySearch(highlightList.subList(0, i), highlightList.get(i)) + 1);
        Collections.rotate(highlightList.subList(j, i + 1), j - i);
        notifyItemMoved(i, j);
    }
}
 
開發者ID:fekracomputers,項目名稱:IslamicLibraryAndroid,代碼行數:12,代碼來源:HighlightRecyclerViewAdapter.java

示例6: createUnequalTestCasesFor

import java.util.Collections; //導入方法依賴的package包/類
private static List<List<?>> createUnequalTestCasesFor(Md5sum... md5sums) {
    List<List<?>> result = new ArrayList<>();
    List<Md5sum> input = ImmutableList.copyOf(md5sums);
    ArrayList<Md5sum> shifting = Lists.newArrayList(md5sums);
    for (int i = 1; i < md5sums.length; i++) {
        Collections.rotate(shifting, 1);
        result.addAll(zip(input, shifting));
    }
    return result;
}
 
開發者ID:TNG,項目名稱:ArchUnit,代碼行數:11,代碼來源:SourceTest.java

示例7: moveRowsUp

import java.util.Collections; //導入方法依賴的package包/類
public Boolean moveRowsUp(int from, int to) {
    if (from - 1 < 0) {
        return false;
    }
    to = to + 1;
    Collections.rotate(records.subList(from - 1, to), -1);
    setSaved(false);
    return true;
}
 
開發者ID:CognizantQAHub,項目名稱:Cognizant-Intelligent-Test-Scripter,代碼行數:10,代碼來源:AbstractDataModel.java

示例8: moveRowsDown

import java.util.Collections; //導入方法依賴的package包/類
public Boolean moveRowsDown(int from, int to) {
    if (to + 1 > records.size() - 1) {
        return false;
    }
    to += 1;
    Collections.rotate(records.subList(from, to + 1), 1);
    setSaved(false);
    return true;
}
 
開發者ID:CognizantQAHub,項目名稱:Cognizant-Intelligent-Test-Scripter,代碼行數:10,代碼來源:AbstractDataModel.java

示例9: moveRowsUp

import java.util.Collections; //導入方法依賴的package包/類
@JsonIgnore
public Boolean moveRowsUp(int from, int to) {
    if (from - 1 < 0) {
        return false;
    }
    to = to + 1;
    Collections.rotate(attributes.subList(from - 1, to), -1);
    changeSave();
    return true;
}
 
開發者ID:CognizantQAHub,項目名稱:Cognizant-Intelligent-Test-Scripter,代碼行數:11,代碼來源:WebORObject.java

示例10: annotateSubtitleFile

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Parse a subtitle file and add annotation if dictionary definitions were found.
 *
 * @return true if at least one annotation was added, false otherwise.
 */
public String[] annotateSubtitleFile(String fileName, String fileContents) throws IOException, FatalParsingException {
  SubtitleFile subtitle = new SubtitleFile(fileName, fileContents, config.getSubtitleStyles());

  // Loop through the subtitle file captions one by one
  while (subtitle.hasNext()) {
    String currentCaptionText = subtitle.nextCaption();
    List<String> colors = new ArrayList<>(config.getHighlightColors());

    // Parse subtitle and lookup definitions
    List<String> alreadyDefinedWords = new ArrayList<>();
    List<String> annotations = new ArrayList<>();
    for (DictionaryMatch match : getFilteredMatches(currentCaptionText)) {
      String color = colors.iterator().next();
      List<String> tokenDefs = annotateDictionaryMatch(match, color);
      if (!tokenDefs.isEmpty() && !alreadyDefinedWords.contains(match.getTextForm())) {
        annotations.addAll(tokenDefs);
        // Set a different color for words that are defined
        subtitle.colorizeCaptionWord(match.getTextForm(), color);
        Collections.rotate(colors, -1);
        alreadyDefinedWords.add(match.getTextForm());
      }
    }
    subtitle.annotate(annotations);
  }

  return subtitle.getNbCaptionAnnotated() == 0 ? null : subtitle.toAssFormat();
}
 
開發者ID:juliango202,項目名稱:jijimaku,代碼行數:33,代碼來源:AnnotationService.java

示例11: moveRowsDown

import java.util.Collections; //導入方法依賴的package包/類
@JsonIgnore
public Boolean moveRowsDown(int from, int to) {
    if (to + 1 > attributes.size() - 1) {
        return false;
    }
    to += 1;
    Collections.rotate(attributes.subList(from, to + 1), 1);
    changeSave();
    return true;
}
 
開發者ID:CognizantQAHub,項目名稱:Cognizant-Intelligent-Test-Scripter,代碼行數:11,代碼來源:MobileORObject.java

示例12: getNeighbors

import java.util.Collections; //導入方法依賴的package包/類
private List<NodeId> getNeighbors() {
    List<NodeId> nodes = clusterService.getNodes().stream()
            .map(ControllerNode::id)
            .collect(Collectors.toCollection(ArrayList::new));
    // sort neighbors by id
    Collections.sort(nodes, (node1, node2) ->
            node1.toString().compareTo(node2.toString()));
    // rotate the local node to index 0
    Collections.rotate(nodes, -1 * nodes.indexOf(clusterService.getLocalNode().id()));
    log.debug("neighbors (raw): {}", nodes); //TODO remove
    // generate the sub-list that will contain local node and selected neighbors
    nodes = nodes.subList(0, numNeighbors + 1);
    log.debug("neighbors: {}", nodes); //TODO remove
    return nodes;
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:16,代碼來源:IntentPerfInstaller.java

示例13: moveRowsDown

import java.util.Collections; //導入方法依賴的package包/類
public Boolean moveRowsDown(int from, int to) {
    if (to + 1 > testSteps.size() - 1) {
        return false;
    }
    to += 1;
    Collections.rotate(testSteps.subList(from, to + 1), 1);
    setSaved(false);
    return true;
}
 
開發者ID:CognizantQAHub,項目名稱:Cognizant-Intelligent-Test-Scripter,代碼行數:10,代碼來源:TestCase.java

示例14: quietRotate

import java.util.Collections; //導入方法依賴的package包/類
private void quietRotate() { //Doesn't return, and doesn't update the rotation counter. Use this for the pre-caching, as initial rotation is arbitrary.
	Collections.rotate(contents,1);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-systemtest,代碼行數:4,代碼來源:SolverTest.java

示例15: stressPopCoding

import java.util.Collections; //導入方法依賴的package包/類
private CodingMethod stressPopCoding(CodingMethod coding) {
    assert(stress != null);  // this method is only for testing
    // Don't turn it into a pop coding if it's already something special.
    if (!(coding instanceof Coding))  return coding;
    Coding valueCoding = ((Coding)coding).getValueCoding();
    Histogram hist = getValueHistogram();
    int fVlen = stressLen(hist.getTotalLength());
    if (fVlen == 0)  return coding;
    List<Integer> popvals = new ArrayList<>();
    if (stress.nextBoolean()) {
        // Build the population from the value list.
        Set<Integer> popset = new HashSet<>();
        for (int i = start; i < end; i++) {
            if (popset.add(values[i]))  popvals.add(values[i]);
        }
    } else {
        int[][] matrix = hist.getMatrix();
        for (int mrow = 0; mrow < matrix.length; mrow++) {
            int[] row = matrix[mrow];
            for (int mcol = 1; mcol < row.length; mcol++) {
                popvals.add(row[mcol]);
            }
        }
    }
    int reorder = stress.nextInt();
    if ((reorder & 7) <= 2) {
        // Lose the order.
        Collections.shuffle(popvals, stress);
    } else {
        // Keep the order, mostly.
        if (((reorder >>>= 3) & 7) <= 2)  Collections.sort(popvals);
        if (((reorder >>>= 3) & 7) <= 2)  Collections.reverse(popvals);
        if (((reorder >>>= 3) & 7) <= 2)  Collections.rotate(popvals, stressLen(popvals.size()));
    }
    if (popvals.size() > fVlen) {
        // Cut the list down.
        if (((reorder >>>= 3) & 7) <= 2) {
            // Cut at end.
            popvals.subList(fVlen,   popvals.size()).clear();
        } else {
            // Cut at start.
            popvals.subList(0, popvals.size()-fVlen).clear();
        }
    }
    fVlen = popvals.size();
    int[] fvals = new int[1+fVlen];
    for (int i = 0; i < fVlen; i++) {
        fvals[1+i] = (popvals.get(i)).intValue();
    }
    PopulationCoding pop = new PopulationCoding();
    pop.setFavoredValues(fvals, fVlen);
    int[] lvals = PopulationCoding.LValuesCoded;
    for (int i = 0; i < lvals.length / 2; i++) {
        int popl = lvals[stress.nextInt(lvals.length)];
        if (popl < 0)  continue;
        if (PopulationCoding.fitTokenCoding(fVlen, popl) != null) {
            pop.setL(popl);
            break;
        }
    }
    if (pop.tokenCoding == null) {
        int lmin = fvals[1], lmax = lmin;
        for (int i = 2; i <= fVlen; i++) {
            int val = fvals[i];
            if (lmin > val)  lmin = val;
            if (lmax < val)  lmax = val;
        }
        pop.tokenCoding = stressCoding(lmin, lmax);
    }

    computePopSizePrivate(pop, valueCoding, valueCoding);
    return pop;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:74,代碼來源:CodingChooser.java


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