java注释类型
Lambda表达式是迄今为止Java 8讨论最多和最受促进的功能。虽然我同意Lambda是一个很大的改进,但我认为其他一些Java 8功能由于Lambda的炒作而有所欠缺。 在这篇文章中,我想展示另一个来自Java 8的出色特性的示例:Type Annotations。
类型注释是可以放置在使用类型的任何位置的注释。 这包括new运算符,类型强制转换,Implements子句和throws子句。 类型注释可以改进对Java代码的分析,并可以确保更强大的类型检查。
在源代码中,这意味着我们获得了两个用于注释的新ElementType:
@Target({ElementType.TYPE_USE, ElementType.TYPE_PARAMETER})
public @interface Test {
}
枚举值TYPE_PARAMETER允许在类型变量(例如MyClass <T>)上应用注释。 目标TYPE_USE的注释可以应用于任何类型的使用。
请注意,发布Java 8时,以下示例的注释将无法立即使用。 Java 8仅提供定义这些注释类型的功能。 然后由框架和工具开发人员实际使用它。 因此,这是将来可能为我们提供的注释框架的集合。 大多数示例取自“ 类型注释”规范和各种Java 8演示。
具有类型注释的简单类型定义如下所示:
@NotNull String str1 = ...
@Email String str2 = ...
@NotNull @NotBlank String str3 = ...
类型注释也可以应用于嵌套类型
Map.@NonNull Entry = ...
具有类型注释的构造函数:
new @Interned MyObject()
new @NonEmpty @Readonly List<String>(myNonEmptyStringSet)
它们也与嵌套(非静态)类构造函数一起工作:
myObject.new @Readonly NestedClass()
类型转换:
myString = (@NonNull String) myObject;
query = (@Untainted String) str;
遗产:
class UnmodifiableList<T> implements @Readonly List<T> { ... }
我们可以将类型注释与泛型类型参数一起使用:
List<@Email String> emails = ...
List<@ReadOnly @Localized Message> messages = ...
Graph<@Directional Node> directedGraph = ...
当然,我们可以嵌套它们:
Map<@NonNull String, @NonEmpty List<@Readonly Document>> documents;
或将它们应用于交集类型:
public <E extends @ReadOnly Composable<E> & @Localized MessageSource> void foo(...) { ... }
包括参数范围和通配符范围:
class Folder<F extends @Existing File> { ... }
Collection<? super @Existing File> c = ...
List<@Immutable ? extends Comparable<T>> unchangeable = ...
具有类型注释的泛型方法调用如下所示:
myObject.<@NotBlank String>myMethod(...);
对于泛型构造函数,注释遵循显式类型参数:
new <String> @Interned MyObject()
抛出异常:
void monitorTemperature() throws @Critical TemperatureException { ... }
void authenticate() throws @Fatal @Logged AccessDeniedException { ... }
在instanceof语句中键入注释:
boolean isNonNull = myString instanceof @NonNull String;
boolean isNonBlankEmail = myString instanceof @NotBlank @Email String;
最后是Java 8方法和构造函数参考:
@Vernal Date::getDay
List<@English String>::size
Arrays::<@NonNegative Integer>sort
结论
类型注释是对Java类型系统的有趣补充。 它们可以应用于任何类型的使用,并可以进行更详细的代码分析。 如果要立即使用Type批注,则应查看Checker Framework 。
参考:来自我们的JCG合作伙伴 Michael Scharhag的Java 8类型注释 ,位于mscharhag,Programming and Stuff博客中。
翻译自: https://www.javacodegeeks.com/2014/02/java-8-type-annotations.html
java注释类型