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


Java SortedSet.comparator方法代碼示例

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


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

示例1: containsAll

import java.util.SortedSet; //導入方法依賴的package包/類
/**
 * Returns {@code true} if every element in {@code values} is {@linkplain #contains contained} in
 * this range.
 */
public boolean containsAll(Iterable<? extends C> values) {
  if (Iterables.isEmpty(values)) {
    return true;
  }

  // this optimizes testing equality of two range-backed sets
  if (values instanceof SortedSet) {
    SortedSet<? extends C> set = cast(values);
    Comparator<?> comparator = set.comparator();
    if (Ordering.natural().equals(comparator) || comparator == null) {
      return contains(set.first()) && contains(set.last());
    }
  }

  for (C value : values) {
    if (!contains(value)) {
      return false;
    }
  }
  return true;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:26,代碼來源:Range.java

示例2: deepCopy

import java.util.SortedSet; //導入方法依賴的package包/類
/**
 * Performs a deep copy of the supplied {@link Map} such that the
 * {@link SortedMap} returned has copies of the supplied {@link
 * Map}'s {@linkplain Map#values() values}.
 *
 * <p>This method may return {@code null} if {@code source} is
 * {@code null}.</p>
 *
 * <p>The {@link SortedMap} returned by this method is
 * mutable.</p>
 *
 * @param source the {@link Map} to copy; may be {@code null} in
 * which case {@code null} will be returned
 *
 * @return a mutable {@link SortedMap}, or {@code null}
 */
private static final SortedMap<String, SortedSet<Entry>> deepCopy(final Map<? extends String, ? extends SortedSet<Entry>> source) {
  final SortedMap<String, SortedSet<Entry>> returnValue;
  if (source == null) {
    returnValue = null;
  } else if (source.isEmpty()) {
    returnValue = Collections.emptySortedMap();
  } else {
    returnValue = new TreeMap<>();
    final Collection<? extends Map.Entry<? extends String, ? extends SortedSet<Entry>>> entrySet = source.entrySet();
    if (entrySet != null && !entrySet.isEmpty()) {
      for (final Map.Entry<? extends String, ? extends SortedSet<Entry>> entry : entrySet) {
        final String key = entry.getKey();
        final SortedSet<Entry> value = entry.getValue();
        if (value == null) {
          returnValue.put(key, null);
        } else {
          final SortedSet<Entry> newValue = new TreeSet<>(value.comparator());
          newValue.addAll(value);
          returnValue.put(key, newValue);
        }
      }
    }
  }
  return returnValue;
}
 
開發者ID:microbean,項目名稱:microbean-helm,代碼行數:42,代碼來源:ChartRepository.java

示例3: isDescending

import java.util.SortedSet; //導入方法依賴的package包/類
public static final boolean isDescending(SortedSet<?> set) {
    if (null == set.comparator()) {
        // natural order
        return false;
    }

    if (Collections.reverseOrder() == set.comparator()) {
        // reverse natural order.
        return true;
    }

    if (set.comparator().equals(Collections.reverseOrder(Collections.reverseOrder(set.comparator())))) {
        // it's a Collections.reverseOrder(Comparator).
        return true;
    }

    throw new IllegalStateException("can't determine ordering for " + set);
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:19,代碼來源:EmptyNavigableSet.java

示例4: comparator

import java.util.SortedSet; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
// if sortedSet.comparator() is null, the set must be naturally ordered
public static <E> Comparator<? super E> comparator(SortedSet<E> sortedSet) {
  Comparator<? super E> result = sortedSet.comparator();
  if (result == null) {
    result = (Comparator<? super E>) Ordering.natural();
  }
  return result;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:10,代碼來源:SortedIterables.java

示例5: SortedSetSubsetTestSetGenerator

import java.util.SortedSet; //導入方法依賴的package包/類
public SortedSetSubsetTestSetGenerator(
    TestSortedSetGenerator<E> delegate, Bound to, Bound from) {
  this.to = to;
  this.from = from;
  this.delegate = delegate;

  SortedSet<E> emptySet = delegate.create();
  this.comparator = emptySet.comparator();

  SampleElements<E> samples = delegate.samples();
  List<E> samplesList = new ArrayList<E>(samples.asList());
  Collections.sort(samplesList, comparator);
  this.firstInclusive = samplesList.get(0);
  this.lastInclusive = samplesList.get(samplesList.size() - 1);
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:16,代碼來源:DerivedCollectionGenerators.java

示例6: hasSameComparator

import java.util.SortedSet; //導入方法依賴的package包/類
private static boolean hasSameComparator(
    Iterable<?> elements, Comparator<?> comparator) {
  if (elements instanceof SortedSet) {
    SortedSet<?> sortedSet = (SortedSet<?>) elements;
    Comparator<?> comparator2 = sortedSet.comparator();
    return (comparator2 == null)
        ? comparator == Ordering.natural()
        : comparator.equals(comparator2);
  }
  return false;
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:12,代碼來源:ImmutableSortedSet.java

示例7: assertSortedSetCharacteristics

import java.util.SortedSet; //導入方法依賴的package包/類
void assertSortedSetCharacteristics(SortedSet<Integer> s, int keyCharacteristics) {
    assertSetCharacteristics(s, keyCharacteristics);

    if (s.comparator() != null) {
        assertNotNullComparator(s);
    }
    else {
        assertNullComparator(s);
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:11,代碼來源:SpliteratorCharacteristics.java

示例8: PriorityBlockingQueue

import java.util.SortedSet; //導入方法依賴的package包/類
/**
 * Creates a {@code PriorityBlockingQueue} containing the elements
 * in the specified collection.  If the specified collection is a
 * {@link SortedSet} or a {@link PriorityQueue}, this
 * priority queue will be ordered according to the same ordering.
 * Otherwise, this priority queue will be ordered according to the
 * {@linkplain Comparable natural ordering} of its elements.
 *
 * @param  c the collection whose elements are to be placed
 *         into this priority queue
 * @throws ClassCastException if elements of the specified collection
 *         cannot be compared to one another according to the priority
 *         queue's ordering
 * @throws NullPointerException if the specified collection or any
 *         of its elements are null
 */
public PriorityBlockingQueue(Collection<? extends E> c) {
    this.lock = new ReentrantLock();
    this.notEmpty = lock.newCondition();
    boolean heapify = true; // true if not known to be in heap order
    boolean screen = true;  // true if must screen for nulls
    if (c instanceof SortedSet<?>) {
        SortedSet<? extends E> ss = (SortedSet<? extends E>) c;
        this.comparator = (Comparator<? super E>) ss.comparator();
        heapify = false;
    }
    else if (c instanceof PriorityBlockingQueue<?>) {
        PriorityBlockingQueue<? extends E> pq =
            (PriorityBlockingQueue<? extends E>) c;
        this.comparator = (Comparator<? super E>) pq.comparator();
        screen = false;
        if (pq.getClass() == PriorityBlockingQueue.class) // exact match
            heapify = false;
    }
    Object[] a = c.toArray();
    int n = a.length;
    // If c.toArray incorrectly doesn't return Object[], copy it.
    if (a.getClass() != Object[].class)
        a = Arrays.copyOf(a, n, Object[].class);
    if (screen && (n == 1 || this.comparator != null)) {
        for (int i = 0; i < n; ++i)
            if (a[i] == null)
                throw new NullPointerException();
    }
    this.queue = a;
    this.size = n;
    if (heapify)
        heapify();
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:50,代碼來源:PriorityBlockingQueue.java

示例9: DynamicSortedSet

import java.util.SortedSet; //導入方法依賴的package包/類
public DynamicSortedSet(SortedSet<E> ss) {
	this.comparator = ss.comparator();
	addAll(ss);
}
 
開發者ID:eclipse,項目名稱:gemini.blueprint,代碼行數:5,代碼來源:DynamicSortedSet.java

示例10: PersistentSortedSet

import java.util.SortedSet; //導入方法依賴的package包/類
/**
 * Constructs a PersistentSortedSet
 *
 * @param session The session
 * @param set The underlying set data
 */
public PersistentSortedSet(SessionImplementor session, SortedSet set) {
	super( session, set );
	comparator = set.comparator();
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:11,代碼來源:PersistentSortedSet.java

示例11: ConcurrentSkipListSet

import java.util.SortedSet; //導入方法依賴的package包/類
/**
 * Constructs a new set containing the same elements and using the
 * same ordering as the specified sorted set.
 *
 * @param s sorted set whose elements will comprise the new set
 * @throws NullPointerException if the specified sorted set or any
 *         of its elements are null
 */
public ConcurrentSkipListSet(SortedSet<E> s) {
    m = new ConcurrentSkipListMap<E,Object>(s.comparator());
    addAll(s);
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:13,代碼來源:ConcurrentSkipListSet.java


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