[LinkedIn] Implement a thread safe hashtable

/*
 * before entering into synchronized method or block thread needs to acquire the lock
 * Here different thread cannot access "put" / "get" from the same instance of hashmap at the same time
 * The lock is obtained at the object level, meaning if t1 is using put(), t2 cannot use get() simultaneously
 */

public ThreadSafeHashMap() {
   items = (LinkedList<Cell<K, V>>[]) new LinkedList[cap];
 }

 public int hashCode(K key) {
   return key.toString().length() % items.length;
 }

 public synchronized void put(K key, V value) {
   int x = hashCode(key);
   if (items[x] == null) {
     items[x] = new LinkedList<Cell<K, V>>();
   }
   LinkedList<Cell<K, V>> list = items[x];
   for (Cell<K, V> c : list) {
     if (c.equals(key)) {
       list.remove(c);
       break;
     }
   }
   Cell<K, V> cell = new Cell<K, V>(key, value);
   list.add(cell);
 }


public synchronized V get(K key) {
   int x = hashCode(key);
   if (items[x] == null) {
     return null;
   }
   LinkedList<Cell<K, V>> list = items[x];
   for (Cell<K, V> c : list) {
     if (c.equals(key)) {
       return c.getValue();
     }
   }
   return null;
 }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值