Java基本注解包括:@Override、@Deprecated、@SuppressWarnings、@SafeVarargs和 @FunctionalInterface
@Override
@Override只能用于方法,子类覆盖父类方法(或者实现接口的方法)时可以@Override注解。编译器 会检查被@Override注解的方法,确保该方法父类中存在的方法,否则会有编译错误。
@Deprecated
@Deprecated用来指示API已经过时了,@Deprecated可以用来注解类、接口、成员方法和成员变量。
@SuppressWarnings
@SuppressWarnings注解用来抑制编译器警告,如果你确认程序中的警告没有问题,可以不用理会。但 是就是不想看到这些警告,可以使用@SuppressWarnings注解消除这些警告。
@SafeVarargs
在声明具有模糊类型(比如:泛型)的可变参数的构造函数或方法时,Java编译器会报unchecked警告。鉴于这些情况,如果程序员断定声明的构造函数和方法的主体不会对其varargs参数执行潜在的不安全的操作,可使用@SafeVarargs进行标记,这样的话,Java编译器就不会报unchecked警告。
示例代码:
public class HelloWorld { public static void main(String[] args) { // 传递可变参数,参数是泛型集合 display(10, 20, 30); // 传递可变参数,参数是非泛型集合 display("10", 20, 30); // 没有@SafeVarargs会有编译警告 } @SafeVarargs public static <T> void display(T... array) { for (T arg : array) { System.out.println(arg.getClass().getName() + ":" + arg); } } }
代码行声明了一种可变参数方法display,display方法参数个数可以变化,它可以接受不确定数量 的相同类型的参数。可以通过在参数类型名后面加入…的方式来表示这是可变参数。可变参数方法中 的参数类型相同,为此声明参数是需要指定泛型。
但是调用可变参数方法时,应该提供相同类型的参数,代码第一个display方法调用时没有警告,而代码第二个display方法调 用时则会发生警告,这个警告是unchecked“未检查不安全代码”,就是由于将非泛型变量赋值给泛型变 量所发生的。
@FunctionalInterface
@FunctionalInterface注解是Java 8增加的,用于接口的注解,声明接口是函数式接口。适用于Lambda表达式。