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


Java LinkedList.listIterator方法代碼示例

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


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

示例1: get

import java.util.LinkedList; //導入方法依賴的package包/類
public synchronized AuthCacheValue get (String pkey, String skey) {
    AuthenticationInfo result = null;
    LinkedList<AuthCacheValue> list = hashtable.get (pkey);
    if (list == null || list.size() == 0) {
        return null;
    }
    if (skey == null) {
        // list should contain only one element
        return (AuthenticationInfo)list.get (0);
    }
    ListIterator<AuthCacheValue> iter = list.listIterator();
    while (iter.hasNext()) {
        AuthenticationInfo inf = (AuthenticationInfo)iter.next();
        if (skey.startsWith (inf.path)) {
            return inf;
        }
    }
    return null;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:20,代碼來源:AuthCacheImpl.java

示例2: put

import java.util.LinkedList; //導入方法依賴的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:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:18,代碼來源:AuthCacheImpl.java

示例3: mergeTo

import java.util.LinkedList; //導入方法依賴的package包/類
private static <T> void mergeTo(List<T> fromList, LinkedList<T> toList, Comparator<T> comparator) {
    if (fromList.isEmpty()) {
        return;
    }
    Iterator<T> fromIterator = fromList.iterator();
    ListIterator<T> toIterator = toList.listIterator();
    T currentFromElement = null;

    if (toIterator.hasNext()) {
        currentFromElement = fromIterator.next();
        while (currentFromElement != null && toIterator.hasNext()) {
            if (comparator.compare(toIterator.next(), currentFromElement) > 0) {
                toIterator.previous();
                toIterator.add(currentFromElement);
                currentFromElement = fromIterator.hasNext() ? fromIterator.next() : null;
            }
        }
    }
    if (currentFromElement != null) {
        toList.add(currentFromElement);
    }
    while (fromIterator.hasNext()) {
        toList.add(fromIterator.next());
    }
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:26,代碼來源:LeadPlanner.java

示例4: main

import java.util.LinkedList; //導入方法依賴的package包/類
public static
void main(String[] args) {
    LinkedList list = new LinkedList();
    ListIterator e = list.listIterator();
    Object o = new Integer(1);
    e.add(o);
    e.previous();
    e.next();
    e.remove();
    e.add(o);
    if (!o.equals(list.get(0)))
        throw new RuntimeException("LinkedList ListIterator remove failed.");
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:14,代碼來源:Remove.java

示例5: findSendablePacket

import java.util.LinkedList; //導入方法依賴的package包/類
private Packet findSendablePacket(LinkedList<Packet> outgoingQueue,
                                  boolean clientTunneledAuthenticationInProgress) {
    synchronized (outgoingQueue) {
        if (outgoingQueue.isEmpty()) {
            return null;
        }
        if (outgoingQueue.getFirst().bb != null // If we've already starting sending the first packet, we better finish
            || !clientTunneledAuthenticationInProgress) {
            return outgoingQueue.getFirst();
        }

        // Since client's authentication with server is in progress,
        // send only the null-header packet queued by primeConnection().
        // This packet must be sent so that the SASL authentication process
        // can proceed, but all other packets should wait until
        // SASL authentication completes.
        ListIterator<Packet> iter = outgoingQueue.listIterator();
        while (iter.hasNext()) {
            Packet p = iter.next();
            if (p.requestHeader == null) {
                // We've found the priming-packet. Move it to the beginning of the queue.
                iter.remove();
                outgoingQueue.add(0, p);
                return p;
            } else {
                // Non-priming packet: defer it until later, leaving it in the queue
                // until authentication completes.
                if (LOG.isDebugEnabled()) {
                    LOG.debug("deferring non-priming packet: " + p +
                            "until SASL authentication completes.");
                }
            }
        }
        // no sendable packet found.
        return null;
    }
}
 
開發者ID:l294265421,項目名稱:ZooKeeper,代碼行數:38,代碼來源:ClientCnxnSocketNIO.java

示例6: prune

import java.util.LinkedList; //導入方法依賴的package包/類
/**
 * Prunes the given list of hypothesis. All hypothesis with an upper utility bound less than the
 * parameter minUtility is pruned.
 */
public LinkedList<Hypothesis> prune(LinkedList<Hypothesis> hypoList, double minUtility, double totalWeight,
		double totalPositiveWeight, double delta_p) {
	double delta_hp = delta_p / hypoList.size();
	ListIterator it = hypoList.listIterator();
	while (it.hasNext()) {
		Hypothesis hypo = (Hypothesis) it.next();
		double upperBound = theUtility.getUpperBound(totalWeight, totalPositiveWeight, hypo, delta_hp);
		if (upperBound < minUtility) {
			it.remove();
		}
	}
	return hypoList;
}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:18,代碼來源:IteratingGSS.java

示例7: processTimerList

import java.util.LinkedList; //導入方法依賴的package包/類
private void  processTimerList( LinkedList<TimerWheelTimer> pList ){
    ListIterator<TimerWheelTimer>  ExpiredTimer = pList.listIterator();

    while (ExpiredTimer.hasNext()){
        try{
            ExpiredTimer.next().getExpiryFunction().invoke(expiryObject, expiryData);
            ExpiredTimer.remove();
            numberOfTimers--;
        }catch(Exception e){
            e.printStackTrace();
        }
        
    }
    pList.clear();
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:16,代碼來源:TimerWheel.java

示例8: doPurge

import java.util.LinkedList; //導入方法依賴的package包/類
private void doPurge(Call call, long now) {
  LinkedList<Call> responseQueue = call.connection.responseQueue;
  synchronized (responseQueue) {
    Iterator<Call> iter = responseQueue.listIterator(0);
    while (iter.hasNext()) {
      call = iter.next();
      if (now > call.timestamp + PURGE_INTERVAL) {
        closeConnection(call.connection);
        break;
      }
    }
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:14,代碼來源:Server.java

示例9: getHeaderNames

import java.util.LinkedList; //導入方法依賴的package包/類
/**
 * Get the header names.
 *
 * @return a list iterator to a list of header names. These are ordered in the same order as
 *         are present in the message.
 */
public ListIterator<String> getHeaderNames() {
    Iterator<SIPHeader> li = this.headers.iterator();
    LinkedList<String> retval = new LinkedList<String>();
    while (li.hasNext()) {
        SIPHeader sipHeader = (SIPHeader) li.next();
        String name = sipHeader.getName();
        retval.add(name);
    }
    return retval.listIterator();
}
 
開發者ID:YunlongYang,項目名稱:LightSIP,代碼行數:17,代碼來源:SIPMessage.java

示例10: packOptionalTlv

import java.util.LinkedList; //導入方法依賴的package包/類
/**
 * Returns writer index.
 *
 * @param cb of type channel buffer.
 * @return writer index
 */
protected int packOptionalTlv(ChannelBuffer cb) {
    int startIndex = cb.writerIndex();

    LinkedList<PcepValueType> llOptionalTlv = this.llOptionalTlv;
    ListIterator<PcepValueType> listIterator = llOptionalTlv.listIterator();
    while (listIterator.hasNext()) {
        PcepValueType tlv = listIterator.next();
        if (tlv == null) {
            log.debug("TLV is null from OptionalTlv list");
            continue;
        }

        tlv.write(cb);

        // need to take care of padding
        int pad = tlv.getLength() % 4;

        if (0 != pad) {
            pad = 4 - pad;
            for (int i = 0; i < pad; ++i) {
                cb.writeByte((byte) 0);
            }
        }
    }
    return cb.writerIndex() - startIndex;
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:33,代碼來源:PcepOpenObjectVer1.java

示例11: capabilityNegotiation

import java.util.LinkedList; //導入方法依賴的package包/類
private void capabilityNegotiation(PcepOpenMsg pOpenmsg) {
    LinkedList<PcepValueType> tlvList = pOpenmsg.getPcepOpenObject().getOptionalTlv();
    boolean pceccCapability = false;
    boolean statefulPceCapability = false;
    boolean pcInstantiationCapability = false;
    boolean labelStackCapability = false;
    boolean srCapability = false;

    ListIterator<PcepValueType> listIterator = tlvList.listIterator();
    while (listIterator.hasNext()) {
        PcepValueType tlv = listIterator.next();

        switch (tlv.getType()) {
        case PceccCapabilityTlv.TYPE:
            pceccCapability = true;
            if (((PceccCapabilityTlv) tlv).sBit()) {
                labelStackCapability = true;
            }
            break;
        case StatefulPceCapabilityTlv.TYPE:
            statefulPceCapability = true;
            StatefulPceCapabilityTlv stetefulPcCapTlv = (StatefulPceCapabilityTlv) tlv;
            if (stetefulPcCapTlv.getIFlag()) {
                pcInstantiationCapability = true;
            }
            break;
        case SrPceCapabilityTlv.TYPE:
            srCapability = true;
            break;
        default:
            continue;
        }
    }
    this.capability = new ClientCapability(pceccCapability, statefulPceCapability, pcInstantiationCapability,
            labelStackCapability, srCapability);
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:37,代碼來源:PcepChannelHandler.java

示例12: getNextHops

import java.util.LinkedList; //導入方法依賴的package包/類
public ListIterator getNextHops(Request request) {
    URI uri = request.getRequestURI();
    ScenarioHarness.assertTrue("Expected to be consulted only for tel uri",uri.getScheme().equals("tel"));
    LinkedList llist = new LinkedList();
    llist.add(new HopImpl());
    return llist.listIterator();
}
 
開發者ID:YunlongYang,項目名稱:LightSIP,代碼行數:8,代碼來源:NonSipUriRouter.java

示例13: lookUpList

import java.util.LinkedList; //導入方法依賴的package包/類
public static UnknownVariable lookUpList(String strName, LinkedList<UnknownVariable> lUnknownVars)	{
	ListIterator<UnknownVariable> itr = lUnknownVars.listIterator();
	String strLowerCaseName = strName.toLowerCase(Locale.US);
	while (itr.hasNext())	{
		UnknownVariable var = itr.next();
		if(var.getName().equals(strLowerCaseName))	{
			return var;
		}
	}
	return null;
}
 
開發者ID:woshiwpa,項目名稱:SmartMath,代碼行數:12,代碼來源:UnknownVarOperator.java

示例14: diff_lineMode

import java.util.LinkedList; //導入方法依賴的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

示例15: parseFile

import java.util.LinkedList; //導入方法依賴的package包/類
/**
 * Parses a file and returns a TimeSeries of type Accel object.
 */
public TimeSeries<Accel> parseFile(String filename) {
  try {
    BufferedReader br = new BufferedReader(new FileReader(filename));
    String line;
    LinkedList<String> lineList = new LinkedList<String>();
    while ((line = br.readLine()) != null) {
      lineList.add(line);
    }
    ListIterator<String> listIterator = lineList.listIterator();
    LinkedList<Accel> interval = new LinkedList<Accel>();
    TimeSeries<Accel> ts = new TimeSeries<Accel>();
    int intervalStart = 0;
    boolean record = false;
    String flag = "";
    while (listIterator.hasNext()) {
      line = listIterator.next();
      String[] split = line.split(" ");
      int time = Integer.parseInt(split[0]);
      if (split[1].equals("START")) {
        if (split[2].equals("17")) {
          record = false;
        }
        flag = split[2];
      } else if (split[1].equals("END")) {
        if (split[2].equals("0")) {
          record = true;
          intervalStart = time;
        }
        flag = "";
      } else if (record) {
        if (time < intervalStart + 50) {
          interval.add(
              new Accel(
                  Integer.parseInt(split[1]),
                  Integer.parseInt(split[2]),
                  Integer.parseInt(split[3])
              )
          );
        } else {
          if (interval.isEmpty()) {
            throw new IllegalArgumentException("Record is incomplete.");
          }
          ts.add(new Point<Accel>(this.meanAccel(interval), flag));
          interval = new LinkedList<Accel>();
          intervalStart += 30;
          boolean backInTime = true;
          while (listIterator.hasPrevious() && backInTime) {
            String[] prevSplit = listIterator.previous().split(" ");
            if (Integer.parseInt(prevSplit[0]) < intervalStart) {
              backInTime = false;
            }
          }
          listIterator.next();
        }
      }
    }
    if (!interval.isEmpty()) {
      ts.add(new Point<Accel>(this.meanAccel(interval), flag));
    }
    return ts;
  } catch (Exception exception) {
    return null;
  }
}
 
開發者ID:GordonLesti,項目名稱:SlidingWindowFilter-evaluator,代碼行數:68,代碼來源:TimeSeriesParser.java


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