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


Java Collections.binarySearch方法代碼示例

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


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

示例1: isValidEndPoint

import java.util.Collections; //導入方法依賴的package包/類
@Override
public boolean isValidEndPoint(final URL url) {
    Assert.notNull(this.httpClient);

    HttpEntity entity = null;

    try (CloseableHttpResponse response = this.httpClient.execute(new HttpGet(url.toURI()))) {
        final int responseCode = response.getStatusLine().getStatusCode();

        final int idx = Collections.binarySearch(this.acceptableCodes, responseCode);
        if (idx >= 0) {
            LOGGER.debug("Response code from server matched [{}].", responseCode);
            return true;
        }

        LOGGER.debug("Response code did not match any of the acceptable response codes. Code returned was [{}]", responseCode);

        if (responseCode == HttpStatus.SC_INTERNAL_SERVER_ERROR) {
            final String value = response.getStatusLine().getReasonPhrase();
            LOGGER.error("There was an error contacting the endpoint: [{}]; The error was:\n[{}]", url.toExternalForm(), value);
        }

        entity = response.getEntity();
    } catch (final Exception e) {
        LOGGER.error(e.getMessage(), e);
    } finally {
        EntityUtils.consumeQuietly(entity);
    }
    return false;
}
 
開發者ID:mrluo735,項目名稱:cas-5.1.0,代碼行數:31,代碼來源:SimpleHttpClient.java

示例2: findItemIndex

import java.util.Collections; //導入方法依賴的package包/類
private int findItemIndex(ArrayList<String> items, int item) {
    //折半查找有序元素的索引
    int index = Collections.binarySearch(items, item, new Comparator<Object>() {
        @Override
        public int compare(Object lhs, Object rhs) {
            String lhsStr = lhs.toString();
            String rhsStr = rhs.toString();
            lhsStr = lhsStr.startsWith("0") ? lhsStr.substring(1) : lhsStr;
            rhsStr = rhsStr.startsWith("0") ? rhsStr.substring(1) : rhsStr;
            return Integer.parseInt(lhsStr) - Integer.parseInt(rhsStr);
        }
    });
    if (index < 0) {
        index = 0;
    }
    return index;
}
 
開發者ID:mainh,項目名稱:MainCalendar,代碼行數:18,代碼來源:DatePicker.java

示例3: keepFoldState

import java.util.Collections; //導入方法依賴的package包/類
private void keepFoldState(Fold newFold, List<Fold> oldFolds) {
	int previousLoc = Collections.binarySearch(oldFolds, newFold);
	//System.out.println(newFold + " => " + previousLoc);
	if (previousLoc>=0) {
		Fold prevFold = oldFolds.get(previousLoc);
		newFold.setCollapsed(prevFold.isCollapsed());
	}
	else {
		//previousLoc = -(insertion point) - 1;
		int insertionPoint = -(previousLoc + 1);
		if (insertionPoint>0) {
			Fold possibleParentFold = oldFolds.get(insertionPoint-1);
			if (possibleParentFold.containsOffset(
					newFold.getStartOffset())) {
				List<Fold> children = possibleParentFold.getChildren();
				if (children!=null) {
					keepFoldState(newFold, children);
				}
			}
		}
	}
}
 
開發者ID:Thecarisma,項目名稱:powertext,代碼行數:23,代碼來源:DefaultFoldManager.java

示例4: findPositionGE

import java.util.Collections; //導入方法依賴的package包/類
private synchronized int findPositionGE(int offset) {
    while (true) {
        try {
            int index = Collections.binarySearch(knownPositions, offset, new PositionComparator());

            if (index >= 0) {
                return index;
            } else {
                return - (index + 1);
            }
        } catch (Abort a) {
            LOG.log(Level.FINE, "a null Position detected - clearing"); //NOI18N
            int removedCount = 0;
            for (Iterator<Reference<Position>> it = knownPositions.iterator(); it.hasNext(); ) {
                if (it.next().get() == null) {
                    removedCount++;
                    it.remove();
                }
            }
            LOG.log(Level.FINE, "clearing finished, {0} positions cleared", removedCount); //NOI18N
        }
    }
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:24,代碼來源:AnnotationHolder.java

示例5: idOfPreviousOrEqual

import java.util.Collections; //導入方法依賴的package包/類
public static <T> Integer idOfPreviousOrEqual(final List<? extends Comparable<? super T>> list, final T key) {
    if (list == null || list.isEmpty()) {
        return null;
    }
    if (list.get(list.size() - 1).compareTo(key) <= 0) {
        return list.size() - 1;
    }
    int idx = Collections.binarySearch(list, key);
    if (idx < 0) {
        idx = -(idx) - 1;
        if (idx != 0 && idx < list.size()) {
            return idx - 1;
        }
        return null;
    }
    return idx;
}
 
開發者ID:iapafoto,項目名稱:DicomViewer,代碼行數:18,代碼來源:SortedListTools.java

示例6: add

import java.util.Collections; //導入方法依賴的package包/類
/**
 *
 */
public int add(Object o)
{
    int index = Collections.binarySearch(elements, o, getComparator());
    if (index < 0)
        index = -index - 1;

    elements.add(index, o);
    fireIntervalAdded(this, index, index);

    return index;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:15,代碼來源:SortedListModel.java

示例7: changedBetweenSnapshots

import java.util.Collections; //導入方法依賴的package包/類
final int[] changedBetweenSnapshots(Snapshot from, Snapshot to) {
  Snapshot earlier = from;
  Snapshot later = to;
  if (Snapshot.ID_COMPARATOR.compare(from, to) > 0) {
    earlier = to;
    later = from;
  }

  final int size = diffs.size();
  int earlierDiffIndex = Collections.binarySearch(diffs, earlier.getId());
  int laterDiffIndex = later == null ? size : Collections
      .binarySearch(diffs, later.getId());
  if (-earlierDiffIndex - 1 == size) {
    // if the earlierSnapshot is after the latest SnapshotDiff stored in
    // diffs, no modification happened after the earlierSnapshot
    return null;
  }
  if (laterDiffIndex == -1 || laterDiffIndex == 0) {
    // if the laterSnapshot is the earliest SnapshotDiff stored in diffs, or
    // before it, no modification happened before the laterSnapshot
    return null;
  }
  earlierDiffIndex = earlierDiffIndex < 0 ? (-earlierDiffIndex - 1)
      : earlierDiffIndex;
  laterDiffIndex = laterDiffIndex < 0 ? (-laterDiffIndex - 1)
      : laterDiffIndex;
  return new int[]{earlierDiffIndex, laterDiffIndex};
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:29,代碼來源:AbstractINodeDiffList.java

示例8: intersects

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Returns true if the span defined by the half-open
 * interval from <code>start</code> up to,
 * but not including, <code>end</code> intersects
 * any of the spans defined by this instance.
 */
public boolean intersects(float start, float end) {
    boolean doesIntersect;

    if (mSpans != null) {

        /* If we have added any spans since we last
         * sorted and collapsed our list of spans
         * then we need to resort and collapse.
         */
        if (mAddsSinceSort > 0) {
            sortAndCollapse();
        }

        /* The SpanIntersection comparator considers
         * two spans equal if they intersect. If
         * the search finds a match then we have an
         * intersection.
         */
        int found = Collections.binarySearch(mSpans,
                                             new Span(start, end),
                                             SpanIntersection.instance);

        doesIntersect = found >= 0;

    /* The addInfinite() method has been invoked so
     * everything intersect this instance.
     */
    } else {
       doesIntersect = true;
    }

    return doesIntersect;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:40,代碼來源:Spans.java

示例9: returnBuf

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Returns a buffer to the pool, throwing away old buffers if the pool would exceed its allotted
 * size.
 *
 * @param buf the buffer to return to the pool.
 */
public synchronized void returnBuf(byte[] buf) {
    if (buf == null || buf.length > mSizeLimit) {
        return;
    }
    mBuffersByLastUse.add(buf);
    int pos = Collections.binarySearch(mBuffersBySize, buf, BUF_COMPARATOR);
    if (pos < 0) {
        pos = -pos - 1;
    }
    mBuffersBySize.add(pos, buf);
    mCurrentSize += buf.length;
    trim();
}
 
開發者ID:wangzhaosheng,項目名稱:publicProject,代碼行數:20,代碼來源:ByteArrayPool.java

示例10: deleteSplitOrphans

import java.util.Collections; //導入方法依賴的package包/類
public int deleteSplitOrphans() {
  final List<SplitRange> ranges = new ArrayList<>();

  int itemsDeleted = 0;
  for(Map.Entry<byte[], NameSpaceContainer> entry : namespace.find()) {
    NameSpaceContainer container = entry.getValue();
    if(container.getType() == Type.DATASET && container.getDataset().getReadDefinition() != null && container.getDataset().getReadDefinition().getSplitVersion() != null) {
      ranges.add(new SplitRange(DatasetSplitId.getSplitStringRange(container.getDataset())));
    }
  }

  for(Map.Entry<DatasetSplitId, DatasetSplit> e : splitsStore.find()) {
    String id = e.getKey().getSplitIdentifier();
    final int item = Collections.binarySearch(ranges, new SplitRange(Range.singleton(id)));

    // we should never find a match since we're searching for a split key.
    Preconditions.checkArgument(item < 0);

    final int insertionPoint = (-item) - 1;
    final int consideredRange = insertionPoint - 1; // since a normal match would come directly after the start range, we need to check the range directly above the insertion point.

    if(consideredRange < 0 || ranges.get(consideredRange).range.contains(id)) {
      splitsStore.delete(e.getKey());
      itemsDeleted++;
    }
  }
  return itemsDeleted;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:29,代碼來源:NamespaceServiceImpl.java

示例11: findPositionIndex

import java.util.Collections; //導入方法依賴的package包/類
private int findPositionIndex(List<Position> positions, final int target) {
    return Collections.binarySearch(positions, new Position() {
        public int getOffset() {
            return target;
        }
    }, new Comparator<Position>() {
        public int compare(Position pos1, Position pos2) {
            return pos1.getOffset() - pos2.getOffset();
        }
    });
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:12,代碼來源:CoverageHighlightsContainer.java

示例12: findStringIndex

import java.util.Collections; //導入方法依賴的package包/類
public int findStringIndex(String s) {
    return Collections.binarySearch(strings, s);
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:4,代碼來源:Dex.java

示例13: spreadBackupsOfThisSuperpeer

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Spread backups of failed superpeer
 *
 * @param p_lastBackupSuperpeer
 *         the last backup superpeer
 * @lock overlay lock must be read-locked
 */
private void spreadBackupsOfThisSuperpeer(final short p_lastBackupSuperpeer) {
    short newBackupSuperpeer;
    int index;
    boolean superpeerToSendData = false;
    byte[] metadata;
    String str = "Spreaded data of ";

    metadata = m_metadata.receiveMetadataInRange(m_predecessor, m_nodeID);

    while (!m_superpeers.isEmpty()) {
        // Determine successor of last backup superpeer
        index = (short) Collections.binarySearch(m_superpeers, (short) (p_lastBackupSuperpeer + 1));
        if (index < 0) {
            index = index * -1 - 1;
            if (index == m_superpeers.size()) {
                index = 0;
            }
        }
        newBackupSuperpeer = m_superpeers.get(index);

        superpeerToSendData = true;
        str += " to " + NodeID.toHexString(newBackupSuperpeer);

        try {
            m_network.sendMessage(new SendBackupsMessage(newBackupSuperpeer, metadata));
        } catch (final NetworkException e) {
            // Superpeer is not available anymore, remove from superpeer array and try next superpeer
            // #if LOGGER >= ERROR
            LOGGER.error("new backup superpeer (0x%X) failed, too", newBackupSuperpeer);
            // #endif /* LOGGER >= ERROR */
            continue;
        }
        break;
    }
    // #if LOGGER >= DEBUG
    if (metadata.length > 0 && superpeerToSendData) {
        LOGGER.debug(str);
    } else {
        LOGGER.debug("No need to spread data");
    }
    // #endif /* LOGGER >= DEBUG */
}
 
開發者ID:hhu-bsinfo,項目名稱:dxram,代碼行數:50,代碼來源:OverlaySuperpeer.java

示例14: findTypeIndex

import java.util.Collections; //導入方法依賴的package包/類
public int findTypeIndex(String descriptor) {
    return Collections.binarySearch(typeNames, descriptor);
}
 
開發者ID:tranleduy2000,項目名稱:javaide,代碼行數:4,代碼來源:Dex.java

示例15: getResponsibleSuperpeer

import java.util.Collections; //導入方法依賴的package包/類
/**
 * Determines the responsible superpeer for given NodeID
 *
 * @param p_nodeID
 *         NodeID from chunk whose location is searched
 * @param p_check
 *         whether the result has to be checked (in case of incomplete superpeer overlay) or not
 * @return the responsible superpeer for given ChunkID
 * @lock overlay lock must be read-locked
 */
private short getResponsibleSuperpeer(final short p_nodeID, final boolean p_check) {
    short responsibleSuperpeer = NodeID.INVALID_ID;
    short predecessor;
    short hisSuccessor;
    int index;
    AskAboutSuccessorRequest request;
    AskAboutSuccessorResponse response;

    // #if LOGGER == TRACE
    LOGGER.trace("Entering getResponsibleSuperpeer with: p_nodeID=0x%X", p_nodeID);
    // #endif /* LOGGER == TRACE */

    if (!m_superpeers.isEmpty()) {
        index = Collections.binarySearch(m_superpeers, p_nodeID);
        if (index < 0) {
            index = index * -1 - 1;
            if (index == m_superpeers.size()) {
                index = 0;
            }
        }
        responsibleSuperpeer = m_superpeers.get(index);

        if (p_check && m_superpeers.size() > 1) {
            if (index == 0) {
                index = m_superpeers.size() - 1;
            } else {
                index--;
            }
            predecessor = m_superpeers.get(index);

            while (true) {
                m_overlayLock.readLock().unlock();
                request = new AskAboutSuccessorRequest(predecessor);
                try {
                    m_network.sendSync(request);
                } catch (final NetworkException e) {
                    // Predecessor is not available, try responsibleSuperpeer without checking
                    m_overlayLock.readLock().lock();
                    break;
                }

                m_overlayLock.readLock().lock();

                response = request.getResponse(AskAboutSuccessorResponse.class);
                hisSuccessor = response.getSuccessor();
                if (responsibleSuperpeer == hisSuccessor) {
                    break;
                } else if (OverlayHelper.isSuperpeerInRange(p_nodeID, predecessor, hisSuccessor)) {
                    responsibleSuperpeer = hisSuccessor;
                    break;
                } else {
                    predecessor = hisSuccessor;
                }
            }
        }
    } else {
        // #if LOGGER >= WARN
        LOGGER.warn("Do not know any superpeer");
        // #endif /* LOGGER >= WARN */
    }
    // #if LOGGER == TRACE
    LOGGER.trace("Exiting getResponsibleSuperpeer");
    // #endif /* LOGGER == TRACE */

    return responsibleSuperpeer;
}
 
開發者ID:hhu-bsinfo,項目名稱:dxram,代碼行數:77,代碼來源:OverlayPeer.java


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