ConcurrentHashMap/ConcurrentMap/Map.compute

Brian Goetz brian.goetz at oracle.com
Wed Dec 5 13:46:21 PST 2012


I'm fine with this.  The existing Map API doesn't say anything about 
atomicity anywhere.  The new putIfAbsent on Map wouldn't promise 
atomicity either; it is no worse than writing

   if (map.containsKey(k))
     map.remove(k)

which we do all the time when we want to do putIfAbsent against 
non-thread-safe maps.  And the maps that promise atomicity can do better 
while using the same client idioms.

The best example of why we want these on Map is computeIfAbsent.  I 
could imagine that Guava never would have bothered with Multimap if 
computeIfAbsent were more convenient.

On 12/5/2012 4:33 PM, Doug Lea wrote:
> On 12/05/12 16:25, Mike Duigou wrote:
>> The problem is that you can't write an atomic putIfAbsent default
>> method in terms of the existing Map API. Thus far we've only
>> contemplated defaults that can match any atomicity expectations
>> provided by the non-default methods.
>>
>
> Right. The idea is that ALL of these would have the same disclaimer as the
> new lambda-friendly ones I listed:
>
>       *
>       * <p>The default implementation makes no guarantees about
>       * synchronization or atomicity properties of this method. Any
>       * class overriding this method must specify its concurrency
>       * properties.
>       *
>
> For CHM and related classes, you need each of the original
> four ConcurrentMap methods, and the four new functional ones
> because without them there's no way to get atomicity
> in these contexts.
> But some people like them for the sake of encapsulating
> common forms under standard names even if not atomic.
> I don't have a strong opinion about it, which is why I asked.
>
> -Doug
>


More information about the lambda-libs-spec-observers mailing list