Java 中引入了 varargs 功能,以便于创建具有可变数量参数的方法,而无需借助数组类型参数或同一方法的重载版本。
在 Java 9 版本之前,如果 vararg 方法与泛型一起使用,则有警告消息。尽管并非所有方法都会产生堆污染,但编译器会针对与泛型一起使用的所有可变参数方法显示警告。这就是 Java 9 版本中添加 @SafeVarargs 概念以避免这些警告的原因。如果我们添加了这个注释,那么编译器就会停止这些警告。
我们可以使用下面的命令来编译代码
<strong>javac -Xlint:unchecked SafeVarargsTest1.java</strong>
在下面的示例中,编译器向用户显示一条警告消息。
import java.util.Arrays; import java.util.List; public class SafeVarargsTest1 { public static void main(String args[]) { SafeVarargsTest1 test = new SafeVarargsTest1(); test.<strong>varargsMethod</strong>(<strong>Arrays.asList</strong>("Adithya", "Jaidev"), Arrays.asList("Raja", "Chaitanya")); } private void varargsMethod(<strong>List<String></strong>... list) { for(List list1: list) System.out.println(list1); } }
<strong>SafeVarargsTest.java:7: warning: [unchecked] unchecked generic array creation for varargs parameter of type List[] test.varargsMethod(Arrays.asList("Adithya", "Jaidev"), Arrays.asList("Raja", "Chaitanya")); ^ SafeVarargsTest.java:9: warning: [unchecked] Possible heap pollution from parameterized vararg type List private void varargsMethod(List... list) { ^ 2 warnings</strong> <strong>[Adithya, Jaidev] [Raja, Chaitanya]</strong>
在下面的示例中,我们应用了@SafeVarargs在私有方法之前。因此,它不会显示任何警告消息。
import java.util.Arrays; import java.util.List; public class SafeVarargsTest2 { public static void main(String args[]) { SafeVarargsTest2 test = new SafeVarargsTest2(); test.<strong>varargsMethod</strong>(Arrays.asList("Adithya", "Jaidev"), Arrays.asList("Raja", "Chaitanya")); } <strong>@SafeVarargs</strong> private void varargsMethod(<strong>List<String></strong>... list) { for(List list1: list) System.out.println(list1); } }
<strong>[Adithya, Jaidev] [Raja, Chaitanya]</strong>
以上是为什么在Java 9中需要使用@SafeVarargs?的详细内容。更多信息请关注PHP中文网其他相关文章!