corda/classpath/java/util/HashSet.java

73 lines
1.3 KiB
Java
Raw Normal View History

2007-07-21 16:36:51 -06:00
package java.util;
public class HashSet<T> implements Set<T> {
private static final Object Value = new Object();
private final HashMap<T, Object> map;
public HashSet(Collection<T> c) {
map = new HashMap(c.size());
addAll(c);
}
2007-07-21 16:36:51 -06:00
public HashSet(int capacity) {
map = new HashMap(capacity);
}
public HashSet() {
this(0);
}
public int size() {
return map.size();
}
public boolean isEmpty() {
return map.isEmpty();
}
2007-07-22 13:06:21 -06:00
public boolean contains(T element) {
return map.containsKey(element);
}
public void addAll(Collection<T> c) {
for (T t: c) add(t);
}
2007-07-21 16:36:51 -06:00
public boolean add(T element) {
return map.put(element, Value) != Value;
}
public boolean remove(T element) {
return map.remove(element) != Value;
}
public void clear() {
map.clear();
}
public Iterator<T> iterator() {
return new MyIterator(map.iterator());
}
private static class MyIterator<T> implements Iterator<T> {
private final Iterator<Map.Entry<T, Object>> it;
public MyIterator(Iterator<Map.Entry<T, Object>> it) {
this.it = it;
}
public T next() {
return it.next().getKey();
}
public boolean hasNext() {
return it.hasNext();
}
public void remove() {
it.remove();
}
}
}