/** {@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);
 }