Request for review: proposal for @FunctionalInterface checking
Joe Darcy
joe.darcy at oracle.com
Sat Dec 29 09:12:06 PST 2012
On 12/28/2012 12:36 PM, Kevin Bourrillion wrote:
> (And yes, I understand the bits about action-at-a-distance and
> documentation value. @Override has those too but /also/ so much more
> value; this doesn't. That still puts it in the same category as most
> of JSR 305.)
>
> Btw what are the costs of adding this annotation?
>
> * One more thing to learn, making lamdas seem some tiny percentage
> more complicated
> * Great potential for user misconception (that it's required), but
> little harm should come of that
> * Companies like mine have one more thing to add to our internal
> style guides (can we use it, should we use it, must we use it?)
>
> The only costs I see are pretty small. However, the benefit also
> looks extremely small to me, and I continue to think it just doesn't
> quite seem to belong.
FWIW, part of adding this annotation type to the JDK would be annotating
the affected platform interfaces so that is a cost we value as
appropriate for the code base.
-Joe
>
>
> On Fri, Dec 28, 2012 at 12:30 PM, Kevin Bourrillion <kevinb at google.com
> <mailto:kevinb at google.com>> wrote:
>
> I see one important difference from @Override. @Override catches
> errors that might otherwise go completely uncaught. With a type
> intended to be a functional interface, the moment anyone ever
> tries to use it as such, there's your compilation error.
>
> So I don't see what sets @FunctionalInterface apart from the whole
> host of static-analysis annotations that we've relegated to the
> now-abandoned JSR 305.
>
>
> On Fri, Dec 28, 2012 at 12:17 PM, Brian Goetz
> <brian.goetz at oracle.com <mailto:brian.goetz at oracle.com>> wrote:
>
> Yes. If you mark an interface as functional, and it is not,
> the compiler will warn/error. This prevents
> action-at-a-distance errors where you have a SAM, other code
> depends on its SAM-ness, and someone later decides to add
> another abstract method (or a method to one of its
> supertypes). It also provide extra documentation value.
>
> Basically, just like @Override.
>
>
> On 12/28/2012 3:16 PM, Sam Pullara wrote:
>
> Is the intent that an interface that is not functional but
> marked as such won't compile?
>
> Sam
>
> On Dec 28, 2012, at 3:12 PM, Brian Goetz
> <brian.goetz at oracle.com <mailto:brian.goetz at oracle.com>>
> wrote:
>
> Note that this proposal does NOT intend to change the
> rule that functional interfaces are recognized
> structurally; single-method interfaces will still be
> recognized as SAMs. This is more like @Override,
> where the user can optionally capture design intent
> and the compiler can warn when said design intent is
> violated.
>
> I support this proposal.
>
> On 12/28/2012 3:02 PM, Joe Darcy wrote:
>
> Hello,
>
> We've had some discussions internally at Oracle
> about adding a
> FunctionalInterface annotation type to the
> platform and we'd now like to
> get the expert group's evaluation and feedback on
> the proposal.
>
> Just as the java.lang.Override annotation type
> allows compile-time
> checking of programmer intent to override a
> method, the goal for the
> FunctionalInterface annotation type is to enable
> analogous compile-time
> checking of whether or not an interface type is
> functional. Draft
> specification:
>
> package java.lang;
>
> /**
> Indicates that an interface type declaration is
> intended to be a
> <i>functional interface</i> as defined by the Java
> Language
> Specification. Conceptually, a functional
> interface has exactly one
> abstract method. Since default methods are not
> abstract, any default
> methods declared in an interface do not contribute
> to its abstract
> method count. If an interface declares a method
> overriding one of the
> public methods of java.lang.Object, that also does
> <em>not</em> count
> toward the abstract method count.
>
> Note that instances of functional interfaces can
> be created with lambda
> expressions, method references, or constructor
> references.
>
> If a type is annotated with this annotation type,
> compilers are required
> to generate an error message unless:
>
> <ul>
> <li> The type is an interface type and not an
> annotation type, enum, or
> class.
> <li> The annotated type satisfies the requirements
> of a functional
> interface.
> </ul>
>
> @jls 9.8 Functional Interfaces
> @jls 9.4.3 Interface Method Body
> @jls 9.6.3.8 FunctionalInterface [Interfaces in
> the java.lang package
> get a corresponding JLS section]
> @since 1.8
> */
> @Documented
> @Retention(RUNTIME)
> @Target(TYPE)
> @interface FunctionalInterface {} // Marker annotation
>
> Annotations on interfaces are *not* inherited,
> which is the proper
> semantics in this case. A subinterface of a
> functional interface can
> add methods and thus not itself be functional.
> There are some
> subtleties to the definition of a functional
> interface, but I thought
> that including those by reference to the JLS was
> sufficient and putting
> in all the details would be more likely to confuse
> than clarify.
>
> Please send comments by January 4, 2013; thanks,
>
> -Joe
>
>
>
>
>
> --
> Kevin Bourrillion | Java Librarian | Google,
> Inc. |kevinb at google.com <mailto:kevinb at google.com>
>
>
>
>
> --
> Kevin Bourrillion | Java Librarian | Google, Inc. |kevinb at google.com
> <mailto:kevinb at google.com>
More information about the lambda-libs-spec-observers
mailing list