下面要给大家介绍的就是java @SafeVarargs注解,这个是比较常见的java注解了,下面一起通过文章内容来进行一下了解吧。
首先的话在对@SafeVarargs注解用法进行介绍之前,我们先来看看代码:
public class HelloWorld { public static void main(String[] args) { // 传递可变参数,参数是泛型集合 display(10, 20, 30); // 传递可变参数,参数是非泛型集合 display("10", 20, 30); // 会有编译警告 } public static <T> void display(T... array) { for (T arg : array) { System.out.println(arg.getClass().getName() + ":" + arg); } } }
在这段代码当中,第10行声明了一种可变参数方法display,display方法参数个数可以变化,它可以接受不确定数量的相同类型的参数,可以通过在参数类型名后面加入的方式来表示这是可变参数,可变参数方法中的参数类型相同,为此声明参数是需要指定泛型。
可是,调用可变参数方法的时候,应该提供相同类型的参数,代码第4行调用的时候,没有警告,而代码第6行调用的时候,就会发生警告,这个警告是unchecked(未检查不安全代码),就是因为将非泛型变量赋值给泛型变量所发生的。
可用@SafeVarargs注解抑制编译器警告,修改代码:
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前添加了@SafeVarargs注解,当然也可以使用 @SuppressWarnings("unchecked") 注解,可是,两者相比较来说的话@SafeVarargs注解更适合。
注意一下,@SafeVarargs注解不适用于非static或非final声明的方法,对于未声明为static或final的方法,假如,要抑制unchecked警告,可以使用@SuppressWarnings注解。
以上关于java @SafeVarargs注解你都清楚了吗?更多相关java基础内容,可以继续通过本站来进行了解哦。
推荐阅读: