/** {@inheritDoc} */ @Override public boolean equals(Object other) { if (!(other instanceof TLongFloatMap)) { return false; } TLongFloatMap that = (TLongFloatMap) other; if (that.size() != this.size()) { return false; } float[] values = _values; byte[] states = _states; float this_no_entry_value = getNoEntryValue(); float that_no_entry_value = that.getNoEntryValue(); for (int i = values.length; i-- > 0; ) { if (states[i] == FULL) { long key = _set[i]; float that_value = that.get(key); float this_value = values[i]; if ((this_value != that_value) && (this_value != this_no_entry_value) && (that_value != that_no_entry_value)) { return false; } } } return true; }
/** {@inheritDoc} */ public void putAll(TLongFloatMap map) { ensureCapacity(map.size()); TLongFloatIterator iter = map.iterator(); while (iter.hasNext()) { iter.advance(); this.put(iter.key(), iter.value()); } }
/** * Creates a new <code>TLongFloatHashMap</code> instance containing all of the entries in the map * passed in. * * @param map a <tt>TLongFloatMap</tt> that will be duplicated. */ public TLongFloatHashMap(TLongFloatMap map) { super(map.size()); if (map instanceof TLongFloatHashMap) { TLongFloatHashMap hashmap = (TLongFloatHashMap) map; this._loadFactor = hashmap._loadFactor; this.no_entry_key = hashmap.no_entry_key; this.no_entry_value = hashmap.no_entry_value; //noinspection RedundantCast if (this.no_entry_key != (long) 0) { Arrays.fill(_set, this.no_entry_key); } //noinspection RedundantCast if (this.no_entry_value != (float) 0) { Arrays.fill(_values, this.no_entry_value); } setUp((int) Math.ceil(DEFAULT_CAPACITY / _loadFactor)); } putAll(map); }
@Override public int size() { synchronized (mutex) { return m.size(); } }