blob: dc305163fc7e15a1feb5b6d14c915ef49591239c [file] [log] [blame]
/*
* Copyright 2007 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package java.util;
/**
* Skeletal implementation of the Set interface. <a
* href="http://java.sun.com/j2se/1.5.0/docs/api/java/util/AbstractSet.html">[Sun
* docs]</a>
*
* @param <E> the element type.
*/
public abstract class AbstractSet<E> extends AbstractCollection<E> implements
Set<E> {
@Override
public boolean equals(Object o) {
if (o == this) {
return true;
}
if (!(o instanceof Set)) {
return false;
}
Set<?> other = (Set<?>) o;
if (other.size() != size()) {
return false;
}
for (Iterator<?> iter = other.iterator(); iter.hasNext();) {
Object otherItem = iter.next();
if (!contains(otherItem)) {
return false;
}
}
return true;
}
@Override
public int hashCode() {
int hashCode = 0;
for (Iterator<E> iter = iterator(); iter.hasNext();) {
// Sets can have null members
E next = iter.next();
if (next != null) {
hashCode += next.hashCode();
// handle int overflow by coercing to int
hashCode = ~~hashCode;
}
}
return hashCode;
}
@Override
public boolean removeAll(Collection<?> c) {
int size = size();
if (size < c.size()) {
// If the member of 'this' is in 'c', remove it from 'this'.
//
for (Iterator<E> iter = iterator(); iter.hasNext();) {
E o = iter.next();
if (c.contains(o)) {
iter.remove();
}
}
} else {
// Remove every member of 'c' from 'this'.
//
for (Iterator<?> iter = c.iterator(); iter.hasNext();) {
Object o = iter.next();
remove(o);
}
}
return (size != size());
}
}