The implementation of default methods

Brian Goetz brian.goetz at oracle.com
Sat Dec 15 07:56:38 PST 2012


For Iterator.remove, I think the real constraint is: the JDK must 
provide *a* default implementation (since this is only an issue for 
compatibility across JDKs).  Since the only reasonable default would be 
to throw something, we might as well specify what is thrown, since this 
degree of freedom serves noone: the JDK must provide a default that 
throws UOE.

On 12/15/2012 1:50 AM, David Holmes wrote:
> 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