@SuppressWarnings 

J2SE 提供的一个批注或者注解。该批注的作用是给编译器一条指令,告诉它对被批注的代码元素内部的某些警告保持静默,即忽略这些警告信息。 


在平常的编码过程中,我们经常使用到的是unchecked,serial这些。 


@SuppressWarnings()中可传入一个字符串数组,数组中列出需要忽略的情况。 

如果传入多种情况,这几种情况的处理同时执行。例如:

Java代码 ​@SuppressWarnings("serial")注解_编译器


  1. @SuppressWarnings({"unchecked","serial"})
  2. public void test(){
  3. //
  4. }


Java代码 @SuppressWarnings("serial")注解_序列化_02


  1. @SuppressWarnings({"unchecked","serial"})
  2. public void test(){
  3. //
  4. }



若是只忽略一种情况的话,就可以写成这样

Java代码 ​@SuppressWarnings("serial")注解_编译器


  1. @SuppressWarnings("unchecked")
  2. public void test(){
  3. //
  4. }


Java代码 @SuppressWarnings("serial")注解_序列化_02


  1. @SuppressWarnings("unchecked")
  2. public void test(){
  3. //
  4. }



以下是主要的几种情况:

关键字

用途

deprecation

使用了已过时或者不推荐使用的类或方法时的警告

unchecked

执行了未检查的转换时的警告,例如当使用集合时没有用泛型 (Generics) 来指定集合保存的类型

fallthrough

当 Switch 程序块直接通往下一种情况而没有 Break 时的警告

path

在类路径、源文件路径等中有不存在的路径时的警告

serial

当在可序列化的类上缺少 serialVersionUID 定义时的警告

all

关于以上所有情况的警告


关键字

用途

deprecation

使用了已过时或者不推荐使用的类或方法时的警告

unchecked

执行了未检查的转换时的警告,例如当使用集合时没有用泛型 (Generics) 来指定集合保存的类型

fallthrough

当 Switch 程序块直接通往下一种情况而没有 Break 时的警告

path

在类路径、源文件路径等中有不存在的路径时的警告

serial

当在可序列化的类上缺少 serialVersionUID 定义时的警告

all

关于以上所有情况的警告




简介:java.lang.SuppressWarnings是J2SE 5.0中标准的Annotation之一。可以标注在类、字段、方法、参数、构造方法,以及局部变量上。

作用:告诉编译器忽略指定的警告,不用在编译完成后出现警告信息。

使用:

@SuppressWarnings(“”)

@SuppressWarnings({})

@SuppressWarnings(value={})



根据sun的官方文档描述:

value - 将由编译器在注释的元素中取消显示的警告集。允许使用重复的名称。忽略第二个和后面出现的名称。出现未被识别的警告名不是 错误:编译器必须忽略无法识别的所有警告名。但如果某个注释包含未被识别的警告名,那么编译器可以随意发出一个警告。

各编译器供应商应该将它们所支持的警告名连同注释类型一起记录。鼓励各供应商之间相互合作,确保在多个编译器中使用相同的名称。

示例:

·   @SuppressWarnings("unchecked")

告诉编译器忽略 unchecked 警告信息,如使用List,ArrayList等未进行参数化产生的警告信息。

·   @SuppressWarnings("serial")

如果编译器出现这样的警告信息:The serializable class WmailCalendar does not declare a static final serialVersionUID field of type long

       使用这个注释将警告信息去掉。

·   @SuppressWarnings("deprecation")

如果使用了使用@Deprecated注释的方法,编译器将出现警告信息。

       使用这个注释将警告信息去掉。

·   @SuppressWarnings("unchecked", "deprecation")

告诉编译器同时忽略unchecked和deprecation的警告信息。

·   @SuppressWarnings(value={"unchecked", "deprecation"})

等同于@SuppressWarnings("unchecked", "deprecation")