java @SafeVarargs注解详解

KLQ 2020-08-18 16:35:57 java常见问答 6262

下面要给大家介绍的就是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基础内容,可以继续通过本站来进行了解哦。

推荐阅读:

java @SuppressWarnings注解详解

java @Deprecated注解详解

java注解(Annotation)概念和作用介绍