@SafeVarargs在JDK 7中引入,主要目的是处理可变长参数中的泛型,此注解告诉编译器:在可变长参数中的泛型是类型安全的。可变长参数是使用数组存储的,而数组和泛型不能很好的混合使用。
数组元素的数据类型在编译和运行时都是确定的,而泛型的数据类型只有在运行时才能确定下来,因此当把一个泛型存储到数组中时,编译器在编译阶段无法检查数据类型是否匹配,因此会给出警告信息。
这里使用了-Xlint:unchecked参数,排查出未经检查的和不安全的操作。其实这里的代码是没有问题的,所以加上注解可以通过编译。
@SafeVarargs注解只能用在参数长度可变的方法或构造方法上,且方法必须声明为static或final,否则会出现编译错误。
还有一种是错误使用的方式,比如下面的代码加上@SafeVarargs注解可以通过编译,但是你看看能发现什么问题?
并且我们编译是可以通过的
但是我们这里去掉@SafeVarargs后,重新编译,会曝出如下错误,可能受到污染,但是还要自己查的哈!
参考:http://softlab.sdut.edu.cn/blog/subaochen/2017/04/safevarargs%E7%9A%84%E7%94%A8%E6%B3%95/
对于javac命令是官方给我们提供的编译工具,但是我们还有很多Non-Standard Options可以选择,这么多不熟悉的操作真的让人眼花缭乱,可以打印出编译过程中遇到的警告,如下图: