All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.carrotsearch.hppc.ObjectIdentityHashSet Maven / Gradle / Ivy

There is a newer version: 4.15.102
Show newest version
package com.carrotsearch.hppc;

import static com.carrotsearch.hppc.HashContainers.*;
import static com.carrotsearch.hppc.Containers.*;

/**
 * A reference-equality (identity) hash set.
 */
public class ObjectIdentityHashSet extends ObjectHashSet {
  /**
   * New instance with sane defaults.
   */
  public ObjectIdentityHashSet() {
    this(DEFAULT_EXPECTED_ELEMENTS, DEFAULT_LOAD_FACTOR);
  }

  /**
   * New instance with sane defaults.
   */
  public ObjectIdentityHashSet(int expectedElements) {
    this(expectedElements, DEFAULT_LOAD_FACTOR);
  }

  /**
   * New instance with sane defaults.
   */
  public ObjectIdentityHashSet(int expectedElements, double loadFactor) {
    this(expectedElements, loadFactor, HashOrderMixing.randomized());
  }

  /**
   * New instance with the provided defaults.
   * 
   * @param expectedElements
   *          The expected number of elements guaranteed not to cause a rehash (inclusive).
   * @param loadFactor
   *          The load factor for internal buffers. Insane load factors (zero, full capacity)
   *          are rejected by {@link #verifyLoadFactor(double)}.
   * @param orderMixer
   *          Hash key order mixing strategy. See {@link HashOrderMixing} for predefined
   *          implementations. Use constant mixers only if you understand the potential
   *          consequences.
   */
  public ObjectIdentityHashSet(int expectedElements, double loadFactor, HashOrderMixingStrategy orderMixer) {
    this.orderMixer = orderMixer;
    this.loadFactor = verifyLoadFactor(loadFactor);
    ensureCapacity(expectedElements);
  }

  /**
   * New instance copying elements from another {@link ObjectContainer}.
   */
  public ObjectIdentityHashSet(ObjectContainer container) {
    this(container.size());
    addAll(container);
  }
  
  @Override
  protected int hashKey(KType key) {
    assert key != null; // Handled as a special case (empty slot marker).
    return BitMixer.mix(key, this.keyMixer);
  }
  
  @Override
  protected boolean equals(Object v1, Object v2) {
    return v1 == v2;
  }
  
  /**
   * Create a set from a variable number of arguments or an array of
   * KType. The elements are copied from the argument to the
   * internal buffer.
   */
  @SafeVarargs
  public static  ObjectIdentityHashSet from(KType... elements) {
    final ObjectIdentityHashSet set = new ObjectIdentityHashSet(elements.length);
    set.addAll(elements);
    return set;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy