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