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


Java MutablePair類代碼示例

本文整理匯總了Java中org.apache.commons.lang3.tuple.MutablePair的典型用法代碼示例。如果您正苦於以下問題:Java MutablePair類的具體用法?Java MutablePair怎麽用?Java MutablePair使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: getValidEdgePosition

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
private void getValidEdgePosition() {
    // loops through valid road end points and adds valid edges (both ships and roads)
    for (CoordinatePair i : aSessionController.requestValidRoadEndpoints(aSessionController.getPlayerColor())) {
        for (CoordinatePair j : aSessionController.getIntersectionsAndEdges()) {
            if (aSessionController.isAdjacent(i, j)) {

                Pair<CoordinatePair, CoordinatePair> edge = new MutablePair<>(i, j);
                validEdges.add(edge);

                for (EdgeUnit eu : aSessionController.getRoadsAndShips()) {
                    if (eu.hasEndpoint(i) && eu.hasEndpoint(j)) {
                        validEdges.remove(edge);
                    }
                }
            }
        }
    }
}
 
開發者ID:teobaranga,項目名稱:Catan,代碼行數:19,代碼來源:SessionScreen.java

示例2: updateValidEdges

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
void updateValidEdges(List<Pair<CoordinatePair,CoordinatePair>> validEdges) {
 // loops through valid road end points and adds valid edges (both ships and roads)
    for (CoordinatePair i : aSessionController.requestValidRoadEndpoints(aSessionController.getPlayerColor())) {
        for (CoordinatePair j : aSessionController.getIntersectionsAndEdges()) { 
            if (aSessionController.isAdjacent(i, j)) {

                Pair<CoordinatePair, CoordinatePair> edge = new MutablePair<>(i, j);
                validEdges.add(edge);

                for (EdgeUnit eu : aSessionController.getRoadsAndShips()) {
                    if (eu.hasEndpoint(i) && eu.hasEndpoint(j)) {
                        validEdges.remove(edge);
                    }
                }
            }
        } 
    }
}
 
開發者ID:teobaranga,項目名稱:Catan,代碼行數:19,代碼來源:ProgressCardHandler.java

示例3: createChannel

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
public static int createChannel(@Nonnull String name, @Nullable Map<ChannelProperty, String> channelProperties, @Nullable Map<ChannelPermission, Integer> permissions)
{
    MutablePair<ResultType, Object> pair = MutablePair.of(ResultType.INTEGER, -1);
    int id = generator++;
    TeamSpeakAPI.results.put(id, pair);
    final String[] msg = {"createchannel:" + name};
    if (channelProperties != null)
        channelProperties.forEach(((channelProperty, s) -> msg[0] += ":" + channelProperties.toString().toUpperCase() + "=" + s));
    if (permissions != null)
        permissions.forEach(((channelPermission, integer) -> msg[0] += ":" + channelPermission.toString().toLowerCase() + "-" + integer));
    TeamSpeakAPI.publish(id, msg[0]);
    try
    {
        synchronized (pair)
        {
            pair.wait(TeamSpeakAPI.TIMEOUT);
        }
    } catch (Exception ignored) {}
    return (int)pair.getRight();
}
 
開發者ID:SamaGames,項目名稱:SamaGamesAPI,代碼行數:21,代碼來源:TeamSpeakAPI.java

示例4: movePlayers

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
public static List<UUID> movePlayers(@Nonnull List<UUID> uuids, int channelId)
{
    MutablePair<ResultType, Object> pair = MutablePair.of(ResultType.UUID_LIST, new ArrayList<>());
    int id = generator++;
    TeamSpeakAPI.results.put(id, pair);
    final String[] msg = {"move:" + channelId};
    uuids.forEach(uuid -> msg[0] += ":" + uuid);
    TeamSpeakAPI.publish(id, msg[0]);
    try
    {
        synchronized (pair)
        {
            pair.wait(TeamSpeakAPI.TIMEOUT);
        }
    } catch (Exception ignored) {}
    return (List<UUID>) pair.getRight();
}
 
開發者ID:SamaGames,項目名稱:SamaGamesAPI,代碼行數:18,代碼來源:TeamSpeakAPI.java

示例5: getProcNetDevStats

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
public static MutablePair<Long, Long> getProcNetDevStats() throws Exception {
  ProcessBuilder ps = new ProcessBuilder("cat", "/proc/net/dev");
  Process pr = ps.start();
  pr.waitFor();

  BufferedReader in = new BufferedReader(new InputStreamReader(pr.getInputStream()));
  String line;
  int counter = 0;
  long receivedBytes = 0;
  long outBytes = 0;

  while ((line = in.readLine()) != null) {
    System.out.println(counter + ": " + line);
    if (line.contains("eth0")) {
      String[] strs = line.split(" ");
      receivedBytes = Long.parseLong(strs[3]);
      outBytes = Long.parseLong(strs[41]);
      System.out.println(" inBytes = " + receivedBytes + "  outBytes = " + outBytes);
    }
    counter++;
  }
  in.close();

  MutablePair<Long, Long> result = new MutablePair<>(receivedBytes, outBytes);
  return result;
}
 
開發者ID:pinterest,項目名稱:doctorkafka,代碼行數:27,代碼來源:OperatorUtil.java

示例6: copyMap

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
public Map<String, MutablePair<String, CommentsNodeImpl>> copyMap(CommentsNodeImpl parent)
{
    Map<String, MutablePair<String, CommentsNodeImpl>> result = new HashMap<>(this.dataMap.size());
    for (Entry<String, MutablePair<String, CommentsNodeImpl>> entry : this.dataMap.entrySet())
    {
        String keyToCpy = entry.getKey();
        MutablePair<String, CommentsNodeImpl> valueToCpy = entry.getValue();
        CommentsNodeImpl nodeToCpy = valueToCpy.getRight();
        CommentsNodeImpl copiedNode;
        if (nodeToCpy == null)
        {
            copiedNode = null;
        }
        else
        {
            copiedNode = new CommentsNodeImpl(parent);
            copiedNode.dataMap.putAll(nodeToCpy.copyMap(parent));
        }
        MutablePair<String, CommentsNodeImpl> copied = new MutablePair<>(valueToCpy.getLeft(), copiedNode);
        result.put(keyToCpy, copied);
    }
    return result;
}
 
開發者ID:GotoFinal,項目名稱:diorite-configs-java8,代碼行數:24,代碼來源:CommentsNodeImpl.java

示例7: trim

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
@Override
public void trim()
{
    for (Iterator<Entry<String, MutablePair<String, CommentsNodeImpl>>> iterator = this.dataMap.entrySet().iterator(); iterator.hasNext(); )
    {
        Entry<String, MutablePair<String, CommentsNodeImpl>> entry = iterator.next();
        MutablePair<String, CommentsNodeImpl> value = entry.getValue();
        CommentsNodeImpl right = value.getRight();
        if (right != null)
        {
            right.trim();
        }
        if (((right == null) || right.dataMap.isEmpty()) && (value.getLeft() == null))
        {
            iterator.remove();
            continue;
        }
        if (right == null)
        {
            continue;
        }
        right.trim();
    }
}
 
開發者ID:GotoFinal,項目名稱:diorite-configs-java8,代碼行數:25,代碼來源:CommentsNodeImpl.java

示例8: getComment

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
@Override
@Nullable
public String getComment(String path)
{
    MutablePair<String, CommentsNodeImpl> nodePair = this.dataMap.get(path);
    if (nodePair != null)
    {
        String comment = nodePair.getLeft();
        if (comment != null)
        {
            return comment;
        }
    }
    MutablePair<String, CommentsNodeImpl> anyNodePair = this.dataMap.get(ANY);
    if (anyNodePair != null)
    {
        return anyNodePair.getKey();
    }
    return null;
}
 
開發者ID:GotoFinal,項目名稱:diorite-configs-java8,代碼行數:21,代碼來源:CommentsNodeImpl.java

示例9: getNode

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
@Override
public CommentsNodeImpl getNode(String path)
{
    MutablePair<String, CommentsNodeImpl> nodePair = this.dataMap.get(path);
    CommentsNodeImpl node = (nodePair == null) ? null : nodePair.getRight();
    if (node == null)
    {
        MutablePair<String, CommentsNodeImpl> anyNodePair = this.dataMap.get(ANY);
        node = (anyNodePair == null) ? null : anyNodePair.getRight();
        if (node == null)
        {
            CommentsNodeImpl commentsNode = new CommentsNodeImpl(this);
            if (nodePair != null)
            {
                nodePair.setRight(commentsNode);
            }
            else
            {
                this.dataMap.put(path, new MutablePair<>(null, commentsNode));
            }
            return commentsNode;
        }
        return node;
    }
    return node;
}
 
開發者ID:GotoFinal,項目名稱:diorite-configs-java8,代碼行數:27,代碼來源:CommentsNodeImpl.java

示例10: prefixSplitter

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
private Pair<String, String> prefixSplitter(String input) {
    MutablePair<String, String> result = new MutablePair<>("", input);
    if (input.startsWith("Device")) {
        result.setLeft("Device");
        result.setRight(input.replaceFirst("Device", ""));
    } else if (input.startsWith("OperatingSystem")) {
        result.setLeft("Operating System");
        result.setRight(input.replaceFirst("OperatingSystem", ""));
    } else if (input.startsWith("LayoutEngine")) {
        result.setLeft("Layout Engine");
        result.setRight(input.replaceFirst("LayoutEngine", ""));
    } else if (input.startsWith("Agent")) {
        result.setLeft("Agent");
        result.setRight(input.replaceFirst("Agent", ""));
    }
    return result;
}
 
開發者ID:nielsbasjes,項目名稱:yauaa,代碼行數:18,代碼來源:ParseService.java

示例11: reissueContainerRequests

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
/**
 * Issue requests to AM RM Client again if previous container requests expired and were not allocated by Yarn
 * @param amRmClient
 * @param requestedResources
 * @param loopCounter
 * @param resourceRequestor
 * @param containerRequests
 * @param removedContainerRequests
 */
public void reissueContainerRequests(AMRMClient<ContainerRequest> amRmClient, Map<StreamingContainerAgent.ContainerStartRequest, MutablePair<Integer, ContainerRequest>> requestedResources, int loopCounter, ResourceRequestHandler resourceRequestor, List<ContainerRequest> containerRequests, List<ContainerRequest> removedContainerRequests)
{
  if (!requestedResources.isEmpty()) {
    for (Map.Entry<StreamingContainerAgent.ContainerStartRequest, MutablePair<Integer, ContainerRequest>> entry : requestedResources.entrySet()) {
      /*
       * Create container requests again if pending requests were not allocated by Yarn till timeout.
       */
      if ((loopCounter - entry.getValue().getKey()) > NUMBER_MISSED_HEARTBEATS) {
        StreamingContainerAgent.ContainerStartRequest csr = entry.getKey();
        LOG.debug("Request for container {} timed out. Re-requesting container", csr.container);
        removedContainerRequests.add(entry.getValue().getRight());
        ContainerRequest cr = resourceRequestor.createContainerRequest(csr, false);
        entry.getValue().setLeft(loopCounter);
        entry.getValue().setRight(cr);
        containerRequests.add(cr);
      }
    }
  }
}
 
開發者ID:apache,項目名稱:apex-core,代碼行數:29,代碼來源:ResourceRequestHandler.java

示例12: emitTuples

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
/**
 * Implement InputOperator Interface.
 */
@Override
public void emitTuples()
{
  if (currentWindowId <= windowDataManager.getLargestCompletedWindow()) {
    return;
  }
  int count = consumer.getQueueSize();
  if (maxTuplesPerWindow > 0) {
    count = Math.min(count, maxTuplesPerWindow - emitCount);
  }
  for (int i = 0; i < count; i++) {
    Pair<String, Record> data = consumer.pollRecord();
    String shardId = data.getFirst();
    String recordId = data.getSecond().getSequenceNumber();
    emitTuple(data);
    MutablePair<String, Integer> shardOffsetAndCount = currentWindowRecoveryState.get(shardId);
    if (shardOffsetAndCount == null) {
      currentWindowRecoveryState.put(shardId, new MutablePair<String, Integer>(recordId, 1));
    } else {
      shardOffsetAndCount.setRight(shardOffsetAndCount.right + 1);
    }
    shardPosition.put(shardId, recordId);
  }
  emitCount += count;
}
 
開發者ID:apache,項目名稱:apex-malhar,代碼行數:29,代碼來源:AbstractKinesisInputOperator.java

示例13: processTopN

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
private void processTopN(HashMap<String, Number> topNMap, HashMap<String, Object> schemaObj)
{
  @SuppressWarnings("unchecked")
  HashMap<String, Object>[] result = (HashMap<String, Object>[])Array.newInstance(HashMap.class, topNMap.size());

  int j = 0;
  for (Entry<String, Number> e : topNMap.entrySet()) {
    result[j] = new HashMap<String, Object>();
    result[j].put("name", e.getKey());
    String val = formatter.format(e.getValue());
    result[j++].put("value", val);
  }
  if (operator.isWebSocketConnected) {
    schemaObj.put("type", "topN");
    schemaObj.put("n", operator.nInTopN);
    operator.wsoo.input.process(new MutablePair<String, Object>(operator.getFullTopic(operator.topNTopic, schemaObj), result));
  }
  else {
    operator.coo.input.process(topNMap);
  }

}
 
開發者ID:apache,項目名稱:apex-malhar,代碼行數:23,代碼來源:LogstreamWidgetOutputOperator.java

示例14: process

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
@Override
public void process(TimeSeriesData[] tuple)
{
  @SuppressWarnings({"unchecked", "rawtypes"})
  HashMap<String, Number>[] timeseriesMapData = new HashMap[tuple.length];
  int i = 0;
  for (TimeSeriesData data : tuple) {
    HashMap<String, Number> timeseriesMap = Maps.newHashMapWithExpectedSize(2);
    timeseriesMap.put("timestamp", data.time);
    timeseriesMap.put("value", data.data);
    timeseriesMapData[i++] = timeseriesMap;
  }

  if (operator.isWebSocketConnected) {
    HashMap<String, Object> schemaObj = new HashMap<>();
    schemaObj.put("type", "timeseries");
    schemaObj.put("minValue", operator.timeSeriesMin);
    schemaObj.put("maxValue", operator.timeSeriesMax);
    operator.wsoo.input.process(new MutablePair<String, Object>(operator.getFullTopic( operator.timeSeriesTopic, schemaObj), timeseriesMapData));
  } else {
    operator.coo.input.process(tuple);
  }
}
 
開發者ID:apache,項目名稱:apex-malhar,代碼行數:24,代碼來源:WidgetOutputOperator.java

示例15: populateDAG

import org.apache.commons.lang3.tuple.MutablePair; //導入依賴的package包/類
@Override
public void populateDAG(DAG dag, Configuration configuration)
{
  RandomNumberPairGenerator inputOperator = new RandomNumberPairGenerator();
  WindowedOperatorImpl<MutablePair<Double, Double>, MutablePair<MutableLong, MutableLong>, Double> windowedOperator = new WindowedOperatorImpl<>();
  Accumulation<MutablePair<Double, Double>, MutablePair<MutableLong, MutableLong>, Double> piAccumulation = new PiAccumulation();

  windowedOperator.setAccumulation(piAccumulation);
  windowedOperator.setDataStorage(new InMemoryWindowedStorage<MutablePair<MutableLong, MutableLong>>());
  windowedOperator.setWindowStateStorage(new InMemoryWindowedStorage<WindowState>());
  windowedOperator.setWindowOption(new WindowOption.GlobalWindow());
  windowedOperator.setTriggerOption(TriggerOption.AtWatermark().withEarlyFiringsAtEvery(Duration.millis(1000)).accumulatingFiredPanes());

  ConsoleOutputOperator outputOperator = new ConsoleOutputOperator();
  dag.addOperator("inputOperator", inputOperator);
  dag.addOperator("windowedOperator", windowedOperator);
  dag.addOperator("outputOperator", outputOperator);
  dag.addStream("input_windowed", inputOperator.output, windowedOperator.input);
  dag.addStream("windowed_output", windowedOperator.output, outputOperator.input);
}
 
開發者ID:apache,項目名稱:apex-malhar,代碼行數:21,代碼來源:Application.java


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