数据结构:键值对
public static class SimpleEntry<K,V>
implements Entry<K,V>, java.io.Serializable
{
private static final long serialVersionUID = -8499721149061103585L;
//实例域key-value
private final K key;
private V value;
//构造方法
public SimpleEntry(K key, V value) {
this.key = key;
this.value = value;
}
public SimpleEntry(Entry<? extends K, ? extends V> entry) {
this.key = entry.getKey();
this.value = entry.getValue();
}
public K getKey() {
return key;
}
public V getValue() {
return value;
}
public V setValue(V value) {
V oldValue = this.value;
this.value = value;
return oldValue;
}
//覆写了Map中的equals方法
public boolean equals(Object o) {
if (!(o instanceof Map.Entry))
return false;
Map.Entry<?,?> e = (Map.Entry<?,?>)o;
return eq(key, e.getKey()) && eq(value, e.getValue());
}
//根据Map接口推荐的hashCode方法覆写了hashCode方法
public int hashCode() {
return (key == null ? 0 : key.hashCode()) ^
(value == null ? 0 : value.hashCode());
}
public String toString() {
return key + "=" + value;
}
}
方法
1、size()
//返回Map中的key-value中键值对数量
public int size() {
return entrySet().size();
}
2、isEmpty()
//根据Map的size判断Map是否为空
public boolean isEmpty() {
return size() == 0;
}
3、containsValue(Object value)
//根据给定的value,判断Map中是否存在对应的key-value存储此value
public boolean containsValue(Object value) {
//第一步调用entrySet方法将Map转换成一个Set集合
//第二步调用Iterator方法对Set集合中的Entry(就是一个key-value类)进行迭代
Iterator<Entry<K,V>> i = entrySet().iterator();
if (value==null) {
while (i.hasNext()) {
Entry<K,V> e = i.next();
if (e.getValue()==null)
return true;
}
} else {
while (i.hasNext()) {
Entry<K,V> e = i.next();
if (value.equals(e.getValue()))
return true;
}
}
return false;
}
4、containsKey(Object key)
public boolean containsKey(Object key) {
//第一步调用entrySet方法将Map转换成一个Set集合
//第二步调用Iterator方法对Set集合中的Entry(就是一个key-value类)进行迭代
Iterator<Map.Entry<K,V>> i = entrySet().iterator();
//如果key是null,则我们用Iterator判断其中是否存在null的key,存在则返回true
if (key==null) {
while (i.hasNext()) {
Entry<K,V> e = i.next();
if (e.getKey()==null)
return true;
}
} else {
while (i.hasNext()) {
Entry<K,V> e = i.next();
if (key.equals(e.getKey()))
return true;
}
}
//如果不存在则返回false
return false;
}
5、get(Object key)
get(Object key)和containsKey(Object key)的内部代码原理一致,不同点在于如果Map中存在对应的key则返回对应的key-value的value
6、remove(Object key)
//根据给定key删除对应的key-value,并返回key-value的value
public V remove(Object key) {
//第一步调用entrySet方法将Map转换成一个Set集合
//第二步调用Iterator方法对Set集合中的Entry(就是一个key-value类)进行迭代
Iterator<Entry<K,V>> i = entrySet().iterator();
//用于在删除该Entry(key-value)前保存对应的Entry
Entry<K,V> correctEntry = null;
//如果key为空,那么就找Map是否存在key为null的
if (key==null) {
while (correctEntry==null && i.hasNext()) {
Entry<K,V> e = i.next();
if (e.getKey()==null)
correctEntry = e;
}
} else {
while (correctEntry==null && i.hasNext()) {
Entry<K,V> e = i.next();
if (key.equals(e.getKey()))
correctEntry = e;
}
}
//保存对应的value
V oldValue = null;
if (correctEntry !=null) {
oldValue = correctEntry.getValue();
???
i.remove();
}
return oldValue;
}
keySet()
//通过在方法内部
public Set<K> keySet() {
Set<K> ks = keySet;
if (ks == null) {
//一个AbstractSet内部类
ks = new AbstractSet<K>() {
public Iterator<K> iterator() {
//Iterator内部类
return new Iterator<K>() {
private Iterator<Entry<K,V>> i = entrySet().iterator();
public boolean hasNext() {
return i.hasNext();
}
public K next() {
return i.next().getKey();
}
public void remove() {
i.remove();
}
};
}
public int size() {
return AbstractMap.this.size();
}
public boolean isEmpty() {
return AbstractMap.this.isEmpty();
}
public void clear() {
AbstractMap.this.clear();
}
public boolean contains(Object k) {
return AbstractMap.this.containsKey(k);
}
};
keySet = ks;
}
return ks;
}
values()
//返回Map中的集合对应的values集合
public Collection<V> values() {
Collection<V> vals = values;
if (vals == null) {
//在累的内部实现了一个抽象类AbstractCollection
vals = new AbstractCollection<V>() {
//Iterator方法内部实现了Iterator 接口
public Iterator<V> iterator() {
return new Iterator<V>() {
private Iterator<Entry<K,V>> i = entrySet().iterator();
public boolean hasNext() {
return i.hasNext();
}
public V next() {
return i.next().getValue();
}
public void remove() {
i.remove();
}
};
}
public int size() {
return AbstractMap.this.size();
}
public boolean isEmpty() {
return AbstractMap.this.isEmpty();
}
public void clear() {
AbstractMap.this.clear();
}
public boolean contains(Object v) {
return AbstractMap.this.containsValue(v);
}
};
values = vals;
}
return vals;
}
equals()方法
//比较两个AbstractMap是否相等
public boolean equals(Object o) {
//首相判断两个对象是否引用同一个地址,如果是则返回true
if (o == this)
return true;
//如果地址不相等,那我们就需要判断两个对象的类型是否相同,如果不同返回false,
//如果相同则首先将要比较的对象转换成Map类型
if (!(o instanceof Map))
return false;
Map<?,?> m = (Map<?,?>) o;
if (m.size() != size())
return false;
//首相返回本AbstractMap的entrySet,然后依次迭代一个key判断对应的 m 这个AbstractMap中是否存在对应的key,
//如果存在则接着判断对应的key-value的value是否相同
try {
Iterator<Entry<K,V>> i = entrySet().iterator();
while (i.hasNext()) {
Entry<K,V> e = i.next();
K key = e.getKey();
V value = e.getValue();
if (value == null) {
if (!(m.get(key)==null && m.containsKey(key)))
return false;
} else {
if (!value.equals(m.get(key)))
return false;
}
}
} catch (ClassCastException unused) {
return false;
} catch (NullPointerException unused) {
return false;
}
return true;
}
hashCode()
public int hashCode() {
int h = 0;
Iterator<Entry<K,V>> i = entrySet().iterator();
while (i.hasNext())
h += i.next().hashCode();
return h;
}
抽象方法
public abstract Set<Entry<K,V>> entrySet();