ConcurrentHashMap/ConcurrentMap/Map.compute
Doug Lea
dl at cs.oswego.edu
Fri Dec 7 06:10:57 PST 2012
On 12/07/12 08:55, Remi Forax wrote:
> On 12/07/2012 02:46 PM, Brian Goetz wrote:
>> I think David's strategy of reabstracting in ConcurrentMap makes sense. CM
>> changes the semantics of these methods compared to what's in Map. As it turns
>> out, this requires no code change because the existing declaration in CM will
>> act as a reabstraction.
Yes, this is/was my intent.
>
> yes, it's better than providing a semantics that will stab users in the back.
>
Which works out OK for the CM methods.
I'm comforted to see that people now implicitly share my anxiety about
the new function-accepting methods. But that doesn't get me closer to
a resolution :-) So, to re-ask:
> Should the cases of existing ConcurrentMap methods and the new
> function-accepting methods work differently? Suppose
> someone calls computeIfAbsent on a JDK7-compliant
> (but non-JDK) ConcurrentMap that doesn't have an explicit
> override. They would get the non-atomic version. And this is
> considered OK according to the the specs as I wrote them.
> But still surprising to at least some users.
More information about the lambda-libs-spec-observers
mailing list