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