Java Docs says that, putIfAbsent is equivalent to
if (!map.containsKey(key))
return map.put(key, value);
else
return map.get(key);
So if the key exists in the map, it doesn’t update its value. Is this correct?
What if i want to update a keys value based on some criteria? Say expiration time etc.
Would this be a better impl for adding and updating cache?
public void AddToCache(T key, V value)
{
V local = _cache.putifabsent(key, value);
if(local.equals(value) && local.IsExpired() == false){
return;
}
// this is for updating the cache with a new value
_cache.put(key, value);
}
That is correct. It will return the current value that was already in the Map.
A couple things would make your implementation better.
1. You shouldn’t use putIfAbsent to test if it exists, you should only use it when you want to ensure if one does not exist then
putIfAbsent. Instead you should usemap.getto test it’s existence (or map.contains).2. Instead of put you will want to replace, this is because a race condition can occur where the
ifcan be evaluated as false by two or more threads in which one of the two (or more) threads will overwrite the other thread’s puts.What you can do instead is replace
When all is said and done it could look like this