1.SuppressWarnings注解
抑制编译警告
说明各种值
unchecked 是忽略没有检查的警告
rawtypes 是忽略没有指定泛型的警告(传参时没有指定泛型的警告错误)
unused 是忽略没有使用某个变量的警告错误
@SuppressWarnings 可以修饰的程序元素为,查看@Target生成@SupperssWarnings时,不用背,直接点击左侧的黄色提示,就可以选择(注意可以指定生成的位置)
package com.logic.annotation;
/**
* @author logic
* @version 1.0
*/
import java.util.ArrayList;
import java.util.List;
@SuppressWarnings({"rawtypes", "unchecked", "unused"})
public class SuppressWarning_ {
//1. 当我们不希望看到这些警告的时候,可以使用 SuppressWarnings注解来抑制警告信息
//2. 在{""} 中,可以写入你希望抑制(不显示)警告信息
//3. 可以指定的警告类型有
// all,抑制所有警告
// boxing,抑制与封装/拆装作业相关的警告
// //cast,抑制与强制转型作业相关的警告
// //dep-ann,抑制与淘汰注释相关的警告
// //deprecation,抑制与淘汰的相关警告
// //fallthrough,抑制与switch陈述式中遗漏break相关的警告
// //finally,抑制与未传回finally区块相关的警告
// //hiding,抑制与隐藏变数的区域变数相关的警告
// //incomplete-switch,抑制与switch陈述式(enum case)中遗漏项目相关的警告
// //javadoc,抑制与javadoc相关的警告
// //nls,抑制与非nls字串文字相关的警告
// //null,抑制与空值分析相关的警告
// //rawtypes,抑制与使用raw类型相关的警告
// //resource,抑制与使用Closeable类型的资源相关的警告
// //restriction,抑制与使用不建议或禁止参照相关的警告
// //serial,抑制与可序列化的类别遗漏serialVersionUID栏位相关的警告
// //static-access,抑制与静态存取不正确相关的警告
// //static-method,抑制与可能宣告为static的方法相关的警告
// //super,抑制与置换方法相关但不含super呼叫的警告
// //synthetic-access,抑制与内部类别的存取未最佳化相关的警告
// //sync-override,抑制因为置换同步方法而遗漏同步化的警告
// //unchecked,抑制与未检查的作业相关的警告
// //unqualified-field-access,抑制与栏位存取不合格相关的警告
// //unused,抑制与未用的程式码及停用的程式码相关的警告
//4. 关于SuppressWarnings 作用范围是和你放置的位置相关
// 比如 @SuppressWarnings放置在 main方法,那么抑制警告的范围就是 main
// 通常我们可以放置具体的语句, 方法, 类.
//5. 看看 @SuppressWarnings 源码
//(1) 放置的位置就是 TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE
//(2) 该注解类有数组 String[] values() 设置一个数组比如 {"rawtypes", "unchecked", "unused"}
/*
@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
@Retention(RetentionPolicy.SOURCE)
public @interface SuppressWarnings {
String[] value();
}
*/
public static void main(String[] args) {
List list = new ArrayList();
list.add("jack");
list.add("tom");
list.add("mary");
int i;
System.out.println(list.get(1));
}
public void f1() {
// @SuppressWarnings({"rawtypes"})
List list = new ArrayList();
list.add("jack");
list.add("tom");
list.add("mary");
// @SuppressWarnings({"unused"})
int i;
System.out.println(list.get(1));
}
}
2.元注解的基本介绍
JDK 的元 Annotation 用于修饰其他 Annotation
元注解:本身作用不大,看源码时可以知道作用是什么
3.元注解的种类(使用不多,了解,不用深入研究)
- Retention //指定注解的作用范围,三种 SOURCE,CLASS,RUNTIME
- Target //指定注解可以在哪些地方使用
- Documented //指定该注解是否会在javadoc体现
- Inherited //子类会继承父类注解
Retention注解
基本说明
只能用于修饰一个 Annotation 定义,用于指定该 Annotation 可以保留多长时间
@Rentention 包含一个 RetentionPolicy 类型的成员变量,使用 @Rentention时必须为该value成员变量指定值
@Retention的三种值
- RetentionPolicy.SOURCE:编译器使用后,直接丢弃这种策略的注释
- RetentionPolicy.CLASS:编译器将把注解记录在class文件中,当运行 Java 程序时,JVM 不会保留注解 这是默认值
- RetentionPolicy.RUNTIME:编译器将把注解记录在 class 文件中,当运行Java 程序时,JVM 会保留注解,程序可以通过反射获取该注解
Target注解
基本说明
用于修饰Annotation定义,用于指定被修饰的 Annotation 能用于修饰哪些程序元素,@Target 也包含一个名为 value 的成员变量
Documented注解
基本说明
@Documented:用于指定被该元 Annotation 修饰的 Annotation 类将被javadoc工具提取成文档,即在生成文档时,可以看到该注解
说明:定义为Documented的注解必须设置Retention值为RUNTIME
Inherited注解
基本说明
被它修饰的 Annotation 将具有继承性,如果某个类使用了被 @Inherited 修饰的 Annotation,则其子类将自动具有该注解
实际应用中,使用较少,了解即可
1470

被折叠的 条评论
为什么被折叠?



