java safevarargs_@SafeVarargs注解的使用
在聲明具有模糊類型(比如:泛型)的可變參數的構造函數或方法時,Java編譯器會報unchecked警告。鑒于這些情況,如果程序員斷定聲明的構造函數和方法的主體不會對其varargs參數執行潛在的不安全的操作,可使用@SafeVarargs進行標記,這樣的話,Java編譯器就不會報unchecked警告。
先看看@SafeVarargs在Java?SE中的聲明:
packagejava.lang;import java.lang.annotation.*;
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.CONSTRUCTOR, ElementType.METHOD})public @interface SafeVarargs {}
由Java源代碼聲明我們了解到:@SafeVarargs注解,只能用于標記構造函數和方法,由于保留策略聲明為RUNTIME,所以此注解可以在運行時生效。
使用的時候要注意:@SafeVarargs注解,對于非static或非final聲明的方法,不適用,會編譯不通過。
@SafeVarargs使用示例如下:
packageorg.springmorning.demo.javabase.annotation.pre;/***@author春晨
* @date 2019/1/19 9:26
* Copyright ?2019 春晨https://www.cnblogs.com/springmorning/p/10285780.html
*/
public class SafeVarargsAnnotation{privateS[] args;//構造函數可以使用@SafeVarargs標記
@SafeVarargspublicSafeVarargsAnnotation(S... args){this.args =args;
}//此處不能使用@SafeVarargs,因為此方法未聲明為static或final方法,如果要抑制unchecked警告,可以使用@SuppressWarnings注解
@SuppressWarnings("unchecked")//@SafeVarargs
public voidloopPrintArgs(S... args){for(S arg : args) {
System.out.println(arg);
}
}//final方法可以使用@SafeVarargs標記
@SafeVarargspublic final voidprintSelfArgs(S... args){for (S arg : this.args) {
System.out.println(arg);
}
}public static voidmain(String[] args) {
SafeVarargsAnnotation.loopPrintInfo("A", "B", "C");
}//static方法可以使用@SafeVarargs標記
@SafeVarargspublic static voidloopPrintInfo(T ... infos){for(T info : infos) {
System.out.println(info);
}
}
}
如果以上把@SafeVarargs標記注釋掉,在編譯時就會報unchecked警告:
加上@SafeVarargs注解,警告被抑制:
下節繼續
總結
以上是生活随笔為你收集整理的java safevarargs_@SafeVarargs注解的使用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java 并发修改_理解和解决Java并
- 下一篇: 区块链 java 开源_详细介绍Java