The implementation of default methods

David Holmes david.holmes at oracle.com
Fri Dec 14 22:50:24 PST 2012


On 15/12/2012 2:45 AM, Doug Lea wrote:
> On 12/14/12 11:30, Brian Goetz wrote:
>
>> 1. Document "Implementation note: The default implementation
>> currently..."
>
> As always, the fewer of these the better. In j.u/j.u.c, these
> are used mostly for resource limitations (like max threads in FJP)
> that might someday be lifted.
>
>>
>> 2. Document "The default implementation behaves as if..." (Or whatever
>> Doug's
>> proposed wording is.)
>
> In j.u.c, we always say "is behaviorally equivalent to" but I dropped
> the "behaviorally" in Map candidate because someone once told me
> it was overly pedantic :-)
>
>>
>> 3. Document "The default implementation MUST"
>
> Isn't this just the normal spec part, that should precede the default
> implementation part?

I think not. The "normal spec" describes the abstract operation. "The 
default implementation MUST" specifies the concrete implementation.

But it sounds like we do not intend to lock in what these default 
implementations do, so, for example, my version of j.u.Iterator.remove 
doesn't have to throw UnsupportedOperationException if I have some magic 
way of providing a default remove operation - correct?

David

> -Doug
>


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