下面要给大家介绍的就是java @SafeVarargs注解,这个是比较常见的java注解了,下面一起通过文章内容来进行一下了解吧。
首先的话在对@SafeVarargs注解用法进行介绍之前,我们先来看看代码:public class HelloWorld {
public static void main(String[] args) {
// 传递可变参数,参数是泛型集合
display(10, 20, 30);
// 传递可变参数,参数是非泛型集合
display(“10”, 20, 30); // 会有编译警告
}
public static 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 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注解。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/105979.html