hashmap的简单实现 博客分类: Java javathinkinginjavahashmap
程序员文章站
2024-03-26 12:41:47
...
- 来自Thinking In Java【P493】。Java Code1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59package org.vocano.java.tst;
import java.util.*;
public class SimpleHashMap<K,V> extends AbstractMap<K,V> {
// Choose a prime number for the hash table
// size, to achieve a uniform distribution:
static final int SIZE = 997;
// You can't have a physical array of generics,
// but you can upcast to one:
@SuppressWarnings("unchecked")
LinkedList<SimpleEntry<K,V>>[] buckets =
new LinkedList[SIZE];
public V put(K key, V value) {
V oldValue = null;
int index = Math.abs(key.hashCode()) % SIZE;
if(buckets[index] == null)
buckets[index] = new LinkedList<SimpleEntry<K,V>>();
LinkedList<SimpleEntry<K,V>> bucket = buckets[index];
SimpleEntry<K,V> pair = new SimpleEntry<K,V>(key, value);
boolean found = false;
ListIterator<SimpleEntry<K,V>> it = bucket.listIterator();
while(it.hasNext()) {
SimpleEntry<K,V> iPair = it.next();
if(iPair.getKey().equals(key)) {
oldValue = iPair.getValue();
it.set(pair); // Replace old with new
found = true;
break;
}
}
if(!found)
buckets[index].add(pair);
return oldValue;
}
public V get(Object key) {
int index = Math.abs(key.hashCode()) % SIZE;
if(buckets[index] == null) return null;
for(SimpleEntry<K,V> iPair : buckets[index])
if(iPair.getKey().equals(key))
return iPair.getValue();
return null;
}
public Set<Map.Entry<K,V>> entrySet() {
Set<Map.Entry<K,V>> set= new HashSet<Map.Entry<K,V>>();
for(LinkedList<SimpleEntry<K,V>> bucket : buckets) {
if(bucket == null) continue;
for(SimpleEntry<K,V> mpair : bucket)
set.add(mpair);
}
return set;
}
public static void main(String[] args) {
SimpleHashMap<String,String> m =
new SimpleHashMap<String,String>();
m.put("a", "b");
System.out.println(m.get("a"));
}
}
推荐阅读
-
hashmap的简单实现 博客分类: Java javathinkinginjavahashmap
-
发布/订阅(Pub/Sub)模式的简单实现 博客分类: js 开发 发布/订阅(Pub/Sub)模式的简单实现
-
发布/订阅(Pub/Sub)模式的简单实现 博客分类: js 开发 发布/订阅(Pub/Sub)模式的简单实现
-
【转】简单工厂模式和策略模式的区别 博客分类: 设计模式 java工厂设计模式策略设计模式
-
简易购物车业务逻辑类的实现 博客分类: java 简易购物车业务逻辑类
-
java可以实现对图片的裁剪功能么 博客分类: java图片工具类 java工具类图片裁剪处理
-
深入Java集合学习系列:HashMap的实现原理 博客分类: javajust do itmore and more备忘录 javahashmap原理
-
为什么HashMap不是线程安全的 博客分类: java javahashmaphashtable线程安全线程不安全
-
FastJson的简单使用 博客分类: Java Tools FastJson
-
QrCode的实现二维码功能 博客分类: 二维码Java技术研究类 二维码QrCodejavabufferImage