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


Java ListIterator.add方法代碼示例

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


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

示例1: addToExpiryList

import java.util.ListIterator; //導入方法依賴的package包/類
private synchronized void addToExpiryList(HttpConnection conn) {
    long now = System.currentTimeMillis() / 1000;
    long then = now + KEEP_ALIVE;
    if (expiryList.isEmpty()) {
        CacheCleaner cleaner = new CacheCleaner(this);
        if (this.cleanerRef.compareAndSet(null, cleaner)) {
            cleaner.start();
        }
        expiryList.add(new ExpiryEntry(conn, then));
        return;
    }

    ListIterator<ExpiryEntry> li = expiryList.listIterator();
    while (li.hasNext()) {
        ExpiryEntry entry = li.next();

        if (then > entry.expiry) {
            li.previous();
            // insert here
            li.add(new ExpiryEntry(conn, then));
            return;
        }
    }
    // first element of list
    expiryList.add(new ExpiryEntry(conn, then));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:27,代碼來源:ConnectionPool.java

示例2: merge

import java.util.ListIterator; //導入方法依賴的package包/類
/**
 * merges two collections
 *
 * @param first      result list
 * @param second     merges with first list
 * @param comparator
 */
public static <T> void merge(List<T> first, List<T> second, Comparator<T> comparator) {
    ListIterator<T> firstIter = first.listIterator();
    ListIterator<T> secondIter = second.listIterator();

    T a = getNext(firstIter);
    T b = getNext(secondIter);

    while (a != null && b != null) {
        if (comparator.compare(a, b) > 0) {
            firstIter.previous();
            firstIter.add(b);
            firstIter.next();
            b = getNext(secondIter);
        } else {
            a = getNext(firstIter);
        }
    }

    while (b != null) {
        firstIter.add(b);
        b = getNext(secondIter);
    }
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:31,代碼來源:MergeUtil.java

示例3: match

import java.util.ListIterator; //導入方法依賴的package包/類
private void match(ListIterator<Match<T>> lit) {
	Match<T> m = lit.next();
	State<T> state = m.getState();
	m.setMatched(false);
	match(lit, m, state);
	if (skipSearch) {
		if (m.isMatched())
			lit.add(m.spawn(state));
		else if (state == trie.getRoot())
			lit.remove();
	}
	else {
		if (!m.isMatched())
			lit.remove();
	}
}
 
開發者ID:Bibliome,項目名稱:bibliome-java-utils,代碼行數:17,代碼來源:Matcher.java

示例4: put

import java.util.ListIterator; //導入方法依賴的package包/類
public synchronized void put (String pkey, AuthCacheValue value) {
    LinkedList<AuthCacheValue> list = hashtable.get (pkey);
    String skey = value.getPath();
    if (list == null) {
        list = new LinkedList<AuthCacheValue>();
        hashtable.put(pkey, list);
    }
    // Check if the path already exists or a super-set of it exists
    ListIterator<AuthCacheValue> iter = list.listIterator();
    while (iter.hasNext()) {
        AuthenticationInfo inf = (AuthenticationInfo)iter.next();
        if (inf.path == null || inf.path.startsWith (skey)) {
            iter.remove ();
        }
    }
    iter.add(value);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:18,代碼來源:AuthCacheImpl.java

示例5: diff_lineMode

import java.util.ListIterator; //導入方法依賴的package包/類
/**
 * Do a quick line-level diff on both strings, then rediff the parts for
 * greater accuracy.
 * This speedup can produce non-minimal diffs.
 * @param text1 Old string to be diffed.
 * @param text2 New string to be diffed.
 * @param deadline Time when the diff should be complete by.
 * @return Linked List of Diff objects.
 */
private LinkedList<Diff> diff_lineMode(String text1, String text2,
		long deadline) {
	// Scan the text on a line-by-line basis first.
	LinesToCharsResult b = diff_linesToChars(text1, text2);
	text1 = b.chars1;
	text2 = b.chars2;
	List<String> linearray = b.lineArray;

	LinkedList<Diff> diffs = diff_main(text1, text2, false, deadline);

	// Convert the diff back to original text.
	diff_charsToLines(diffs, linearray);
	// Eliminate freak matches (e.g. blank lines)
	diff_cleanupSemantic(diffs);

	// Rediff any replacement blocks, this time character-by-character.
	// Add a dummy entry at the end.
	diffs.add(new Diff(Operation.EQUAL, ""));
	int count_delete = 0;
	int count_insert = 0;
	String text_delete = "";
	String text_insert = "";
	ListIterator<Diff> pointer = diffs.listIterator();
	Diff thisDiff = pointer.next();
	while (thisDiff != null) {
		switch (thisDiff.operation) {
			case INSERT:
				count_insert++;
				text_insert += thisDiff.text;
				break;
			case DELETE:
				count_delete++;
				text_delete += thisDiff.text;
				break;
			case EQUAL:
				// Upon reaching an equality, check for prior redundancies.
				if (count_delete >= 1 && count_insert >= 1) {
					// Delete the offending records and add the merged ones.
					pointer.previous();
					for (int j = 0; j < count_delete + count_insert; j++) {
						pointer.previous();
						pointer.remove();
					}
					for (Diff newDiff : diff_main(text_delete, text_insert, false,
							deadline)) {
						pointer.add(newDiff);
					}
				}
				count_insert = 0;
				count_delete = 0;
				text_delete = "";
				text_insert = "";
				break;
		}
		thisDiff = pointer.hasNext() ? pointer.next() : null;
	}
	diffs.removeLast();  // Remove the dummy entry at the end.

	return diffs;
}
 
開發者ID:phoenixctms,項目名稱:ctsms,代碼行數:70,代碼來源:diff_match_patch.java

示例6: parseData

import java.util.ListIterator; //導入方法依賴的package包/類
private void parseData(Segment newSeg) {
    long sn = newSeg.sn;

    if (itimediff(sn, rcvNxt + rcvWnd) >= 0 || itimediff(sn, rcvNxt) < 0) {
        newSeg.recycle(true);
        return;
    }

    boolean repeat = false;
    boolean findPos = false;
    ListIterator<Segment> listItr = null;
    if (rcvBuf.size() > 0) {
        listItr = rcvBufItr.rewind(rcvBuf.size());
        while (listItr.hasPrevious()) {
            Segment seg = listItr.previous();
            if (seg.sn == sn) {
                repeat = true;
                break;
            }
            if (itimediff(sn, seg.sn) > 0) {
                findPos = true;
                break;
            }
        }
    }

    if (repeat) {
        newSeg.recycle(true);
    } else if (listItr == null) {
        rcvBuf.add(newSeg);
    } else {
        if (findPos) {
            listItr.next();
        }
        listItr.add(newSeg);
    }

    // move available data from rcv_buf -> rcv_queue
    moveRcvData(); // Invoke the method only if the segment is not repeat?
}
 
開發者ID:szhnet,項目名稱:kcp-netty,代碼行數:41,代碼來源:Kcp.java

示例7: testAdd

import java.util.ListIterator; //導入方法依賴的package包/類
/**
 * Test of add method, of class TreeListIterator.
 */
@Test(expected = UnsupportedOperationException.class)
public void testAdd() {
    ListIterator<TreeNode> treeListIterator2 = new TreeListIterator(tree2);
    treeListIterator2.next();
    treeListIterator2.add(null);
}
 
開發者ID:miyagilabs,項目名稱:Blindfold,代碼行數:10,代碼來源:TreeListIteratorTest.java

示例8: diff_lineMode

import java.util.ListIterator; //導入方法依賴的package包/類
/**
 * Do a quick line-level diff on both strings, then rediff the parts for
 * greater accuracy.
 * This speedup can produce non-minimal diffs.
 * @param text1 Old string to be diffed.
 * @param text2 New string to be diffed.
 * @param deadline Time when the diff should be complete by.
 * @return Linked List of Diff objects.
 */
private LinkedList<Diff> diff_lineMode(String text1, String text2,
                                       long deadline) {
  // Scan the text on a line-by-line basis first.
  LinesToCharsResult b = diff_linesToChars(text1, text2);
  text1 = b.chars1;
  text2 = b.chars2;
  List<String> linearray = b.lineArray;

  LinkedList<Diff> diffs = diff_main(text1, text2, false, deadline);

  // Convert the diff back to original text.
  diff_charsToLines(diffs, linearray);
  // Eliminate freak matches (e.g. blank lines)
  diff_cleanupSemantic(diffs);

  // Rediff any replacement blocks, this time character-by-character.
  // Add a dummy entry at the end.
  diffs.add(new Diff(Operation.EQUAL, ""));
  int count_delete = 0;
  int count_insert = 0;
  String text_delete = "";
  String text_insert = "";
  ListIterator<Diff> pointer = diffs.listIterator();
  Diff thisDiff = pointer.next();
  while (thisDiff != null) {
    switch (thisDiff.operation) {
    case INSERT:
      count_insert++;
      text_insert += thisDiff.text;
      break;
    case DELETE:
      count_delete++;
      text_delete += thisDiff.text;
      break;
    case EQUAL:
      // Upon reaching an equality, check for prior redundancies.
      if (count_delete >= 1 && count_insert >= 1) {
        // Delete the offending records and add the merged ones.
        pointer.previous();
        for (int j = 0; j < count_delete + count_insert; j++) {
          pointer.previous();
          pointer.remove();
        }
        for (Diff newDiff : diff_main(text_delete, text_insert, false,
            deadline)) {
          pointer.add(newDiff);
        }
      }
      count_insert = 0;
      count_delete = 0;
      text_delete = "";
      text_insert = "";
      break;
    }
    thisDiff = pointer.hasNext() ? pointer.next() : null;
  }
  diffs.removeLast();  // Remove the dummy entry at the end.

  return diffs;
}
 
開發者ID:liaoziyang,項目名稱:ContentAssist,代碼行數:70,代碼來源:diff_match_patch.java

示例9: transferListIteratorIndirect

import java.util.ListIterator; //導入方法依賴的package包/類
private String transferListIteratorIndirect(String str) {
    List<String> list = new LinkedList<String>();
    // not able to transfer this, set as UNKNOWN even if str is SAFE
    ListIterator<String> listIterator = list.listIterator();
    listIterator.add(str);
    return list.get(0);
}
 
開發者ID:blackarbiter,項目名稱:Android_Code_Arbiter,代碼行數:8,代碼來源:CommandInjection.java

示例10: diff_lineMode

import java.util.ListIterator; //導入方法依賴的package包/類
/**
 * Do a quick line-level diff on both strings, then rediff the parts for
 * greater accuracy. This speedup can produce non-minimal diffs.
 * 
 * @param text1 Old string to be diffed.
 * @param text2 New string to be diffed.
 * @param deadline Time when the diff should be complete by.
 * @return Linked List of Diff objects.
 */
private LinkedList<Diff> diff_lineMode(String text1, String text2, long deadline) {
	// Scan the text on a line-by-line basis first.
	LinesToCharsResult b = diff_linesToChars(text1, text2);
	text1 = b.chars1;
	text2 = b.chars2;
	List<String> linearray = b.lineArray;

	LinkedList<Diff> diffs = diff_main(text1, text2, false, deadline);

	// Convert the diff back to original text.
	diff_charsToLines(diffs, linearray);
	// Eliminate freak matches (e.g. blank lines)
	diff_cleanupSemantic(diffs);

	// Rediff any replacement blocks, this time character-by-character.
	// Add a dummy entry at the end.
	diffs.add(new Diff(Operation.EQUAL, ""));
	int count_delete = 0;
	int count_insert = 0;
	String text_delete = "";
	String text_insert = "";
	ListIterator<Diff> pointer = diffs.listIterator();
	Diff thisDiff = pointer.next();
	while (thisDiff != null) {
		switch (thisDiff.operation) {
			case INSERT:
				count_insert++;
				text_insert += thisDiff.text;
				break;
			case DELETE:
				count_delete++;
				text_delete += thisDiff.text;
				break;
			case EQUAL:
				// Upon reaching an equality, check for prior redundancies.
				if (count_delete >= 1 && count_insert >= 1) {
					// Delete the offending records and add the merged ones.
					pointer.previous();
					for (int j = 0; j < count_delete + count_insert; j++) {
						pointer.previous();
						pointer.remove();
					}
					for (Diff newDiff : diff_main(text_delete, text_insert, false, deadline)) {
						pointer.add(newDiff);
					}
				}
				count_insert = 0;
				count_delete = 0;
				text_delete = "";
				text_insert = "";
				break;
		}
		thisDiff = pointer.hasNext() ? pointer.next() : null;
	}
	diffs.removeLast(); // Remove the dummy entry at the end.

	return diffs;
}
 
開發者ID:jmfgdev,項目名稱:gitplex-mit,代碼行數:68,代碼來源:DiffMatchPatch.java

示例11: decorateResultForIndexMode

import java.util.ListIterator; //導入方法依賴的package包/類
/**
 * 為了索引模式修飾結果
 * 
 * @param vertexList
 * @param wordNetAll
 */
protected static List<Term> decorateResultForIndexMode(
		List<Vertex> vertexList, WordNet wordNetAll) {
	List<Term> termList = new LinkedList<Term>();
	int line = 1;
	ListIterator<Vertex> listIterator = vertexList.listIterator();
	listIterator.next();
	int length = vertexList.size() - 2;
	for (int i = 0; i < length; ++i) {
		Vertex vertex = listIterator.next();
		Term termMain = convert(vertex);
		termList.add(termMain);
		termMain.offset = line - 1;
		if (vertex.realWord.length() > 2) {
			// 過長詞所在的行
			int currentLine = line;
			while (currentLine < line + vertex.realWord.length()) {
				List<Vertex> vertexListCurrentLine = wordNetAll
						.get(currentLine); // 這一行的詞
				for (Vertex smallVertex : vertexListCurrentLine) // 這一行的短詞
				{
					if (((termMain.nature == Nature.mq && smallVertex
							.hasNature(Nature.q)) || smallVertex.realWord
							.length() > 1)
							&& smallVertex != vertex) {
						listIterator.add(smallVertex);
						Term termSub = convert(smallVertex);
						termSub.offset = currentLine - 1;
						termList.add(termSub);
					}
				}
				++currentLine;
			}
		}
		line += vertex.realWord.length();
	}

	return termList;
}
 
開發者ID:priester,項目名稱:hanlpStudy,代碼行數:45,代碼來源:WordBasedGenerativeModelSegment.java

示例12: upsertHint

import java.util.ListIterator; //導入方法依賴的package包/類
private void upsertHint(Credential credential) throws IOException {
    CredentialMeta meta = readCredentialMeta();

    // create a copy of the hints list for modification
    List<AccountHint> hints = new ArrayList<>(readCredentialMeta().getHintsList());

    ListIterator<AccountHint> hintIter = hints.listIterator();
    boolean found = false;
    while (!found && hintIter.hasNext()) {
        AccountHint existingHint = hintIter.next();

        if (existingHint.getIdentifier().equals(credential.getId())
                && existingHint.getAuthMethod().equals(credential.getAuthMethod())
                && CredentialQualityScore.getScore(existingHint)
                        <= CredentialQualityScore.getScore(credential)) {
            hintIter.remove();
            hintIter.add(convertCredentialToHint(credential));
            found = true;
        }
    }

    if (!found) {
        hintIter.add(convertCredentialToHint(credential));
    }

    writeCredentialMeta(meta.toBuilder()
            .clearHints()
            .addAllHints(hints)
            .build());
}
 
開發者ID:openid,項目名稱:OpenYOLO-Android,代碼行數:31,代碼來源:CredentialStorage.java

示例13: createSuites

import java.util.ListIterator; //導入方法依賴的package包/類
@Override
public Suites createSuites(OptionValues options) {
    Suites suites = super.createSuites(options);

    ListIterator<BasePhase<? super LowTierContext>> findPhase = suites.getLowTier().findPhase(FixReadsPhase.class);
    if (findPhase == null) {
        findPhase = suites.getLowTier().findPhase(ExpandLogicPhase.class);
    }
    findPhase.add(new AddressLoweringPhase(addressLowering));

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

示例14: createSuites

import java.util.ListIterator; //導入方法依賴的package包/類
@Override
public Suites createSuites(OptionValues options) {
    Suites ret = defaultSuitesCreator.createSuites(options);

    if (ImmutableCode.getValue(options)) {
        // lowering introduces class constants, therefore it must be after lowering
        ret.getHighTier().appendPhase(new LoadJavaMirrorWithKlassPhase(config));
        if (VerifyPhases.getValue(options)) {
            ret.getHighTier().appendPhase(new AheadOfTimeVerificationPhase());
        }
        if (GeneratePIC.getValue(options)) {
            ListIterator<BasePhase<? super HighTierContext>> highTierLowering = ret.getHighTier().findPhase(LoweringPhase.class);
            highTierLowering.previous();
            highTierLowering.add(new EliminateRedundantInitializationPhase());
            if (HotSpotAOTProfilingPlugin.Options.TieredAOT.getValue(options)) {
                highTierLowering.add(new FinalizeProfileNodesPhase(HotSpotAOTProfilingPlugin.Options.TierAInvokeInlineeNotifyFreqLog.getValue(options)));
            }
            ListIterator<BasePhase<? super MidTierContext>> midTierLowering = ret.getMidTier().findPhase(LoweringPhase.class);
            midTierLowering.add(new ReplaceConstantNodesPhase());

            // Replace inlining policy
            if (Inline.getValue(options)) {
                ListIterator<BasePhase<? super HighTierContext>> iter = ret.getHighTier().findPhase(InliningPhase.class);
                InliningPhase inlining = (InliningPhase) iter.previous();
                CanonicalizerPhase canonicalizer = inlining.getCanonicalizer();
                iter.set(new InliningPhase(new AOTInliningPolicy(null), canonicalizer));
            }
        }
    }

    ret.getMidTier().appendPhase(new WriteBarrierAdditionPhase(config));
    if (VerifyPhases.getValue(options)) {
        ret.getMidTier().appendPhase(new WriteBarrierVerificationPhase(config));
    }

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

示例15: testListIteratorSetFail

import java.util.ListIterator; //導入方法依賴的package包/類
@Test(expected = IllegalStateException.class)
public void testListIteratorSetFail() {
    List<Integer> list = redisson.getList("list");
    list.add(1);

    ListIterator<Integer> iterator = list.listIterator();

    iterator.next();
    iterator.add(2);
    iterator.set(3);
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:12,代碼來源:RedissonListTest.java


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