`

@SuppressWarnings(unchecked)作用解释.doc

阅读更多

解释一:   

       屏蔽某些编译时的警告信息
       
在强制类型转换的时候编译器会给出警告
      
加上

       程序代码

       @SuppressWarnings("unchecked")

       就不会警告了

解释二:

注释类型

当你的编码可能存在警告时,比如安全警告,可以用它来消除

api中是这样描述的

指示应该在注释元素(以及包含在该注释元素中的所有程序元素)中取消显示指定的编译器警告。注意,在给定元素中取消显示的警告集是所有包含元素中取消显示的警告的超集。例如,如果注释一个类来取消显示某个警告,同时注释一个方法来取消显示另一个警告,那么将在此方法中同时取消显示这两个警告。

根据风格不同,程序员应该始终在最里层的嵌套元素上使用此注释,在那里使用才有效。如果要在特定的方法中取消显示某个警告,则应该注释该方法而不是注释它的类。

解释三:

@SuppressWarnings

J2SE 提供的最后一个批注是 @SuppressWarnings。该批注的作用是给编译器一条指令,告诉它对被批注的代码元素内部的某些警告保持静默。

一点背景:J2SE 5.0 Java 语言增加了几个新的特性,并且和它们一起增加了许多新的警告并承诺在将来增加更多的警告。您可以为 "javac" 增加 -Xlint 参数来控制是否报告这些警告(如上面的 @Deprecated 部分所示)。

默认情况下,Sun 编译器以简单的两行的形式输出警告。通过添加 -Xlint:keyword 标记(例如 -Xlint:finally),您可以获得关键字类型错误的完整说明。通过在关键字前面添加一个破折号,写为 -Xlint:-keyword,您可以取消警告。(-Xlint 支持的关键字的完整列表可以在 上找到。)下面是一个清单:

关键字

用途

deprecation

使用了不赞成使用的类或方法时的警告

unchecked

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

fallthrough

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

path

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

serial

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

finally

任何 finally 子句不能正常完成时的警告。

all

关于以上所有情况的警告。

@SuppressWarnings 批注允许您选择性地取消特定代码段(即,类或方法)中的警告。其中的想法是当您看到警告时,您将调查它,如果您确定它不是问题,您就可以添加一个 @SuppressWarnings 批注,以使您不会再看到警告。虽然它听起来似乎会屏蔽潜在的错误,但实际上它将提高代码安全性,因为它将防止您对警告无动于衷您看到的每一个警告都将值得注意。

下面是使用 @SuppressWarnings 来取消 deprecation 警告的一个例子:

public class DeprecatedExample2 { @Deprecated public static void foo() { } } public class DeprecatedUser2 { @SuppressWarnings(value={"deprecation"}) public static void main(String[] args) { DeprecatedExample2.foo(); } }

@SuppressWarnings 批注接收一个 "value" 变量,该变量是一个字符串数组,它指示将取消的警告。合法字符串的集合随编译器而变化,但在 JDK 上,可以传递给 -Xlint 的是相同的关键字集合(非常方便)。并且要求编译器忽略任何它们不能识别的关键字,这在您使用一些不同的编译器时非常方便。

因为 @SuppressWarnings 批注仅接收一个参数,并为该参数使用了特殊的名称 "value",所以您可以选择省略 value=,作为一种方便的缩写:

public class DeprecatedUser2 { @SuppressWarnings({"deprecation"}) public static void main(String[] args) { DeprecatedExample2.foo(); } }

您可以将单个数组参数中的任意数量的字符串值传递给批注,并在任何级别上放置批注。例如,以下示例代码指示将取消整个类的 deprecation 警告,而仅在 main() 方法代码内取消 unchecked fallthrough 警告:

import java.util.*; @SuppressWarnings({"deprecation"}) public class NonGenerics { @SuppressWarnings({"unchecked","fallthrough"}) public static void main(String[] args) { Runtime.runFinalizersOnExit(); List list = new ArrayList(); list.add("foo"); } public static void foo() { List list = new ArrayList(); list.add("foo"); } }

@SuppressWarnings 是否比前两个批注更有用?绝对是这样。不过,在 JDK 1.5.0 版本中还没有完全支持该批注,如果您用 1.5.0 来尝试它,那么它将类似无操作指令。调用 -Xlint:-deprecation 也没有任何效果。Sun 没有声明什么时候将增加支持,但它暗示这将在即将推出的一个 dot 版本中实现。

更进一步

如果您试图在 Javadocs 页面中查看这些属性,那么您可能很难找到它们。它们位于核心的 java.lang 包中,但有点隐蔽,它们出现在 Javadoc 类的最底端,列在 Exceptions Errors 后面。

注意到了附加在 SuppressWarnings 批注后面的陌生的批注 @Target @Retention 了吗?这些称为元数据批注,它们描述了该批注在哪里适用。我将在本系列的第二篇文章中介绍它们,以及介绍如何将元数据批注应用到您自己的批注中。

 

分享到:
评论
6 楼 u013606853 2014-07-25  
你的文章是转载的,为什么不写明转载的地址或链接呢?JAVAEYE不是明确提到过这些要求吗?
5 楼 wjshuang 2013-08-14  
有可能其他地方的这个文档也是博主写的把。
4 楼 javer 2010-11-30  
hanz188 写道
你的文章是转载的,为什么不写明转载的地址或链接呢?JAVAEYE不是明确提到过这些要求吗?

全凭自觉的
3 楼 wa327114652 2010-07-16  
谢谢,学习了!
2 楼 hanz188 2009-10-05  
我注意到文章最后提到这个文章属于一个系列,后面还会有主题相同的其他文章,博主可否将另外几篇文章也贴出来,非常希望看到其他内容。我会长期关注这个博客,谢谢!
1 楼 hanz188 2009-10-05  
你的文章是转载的,为什么不写明转载的地址或链接呢?JAVAEYE不是明确提到过这些要求吗?

相关推荐

    java中的SuppressWarnings(xxx).doc

    在这个例子中,`@SuppressWarnings` 被用来同时忽略 `unchecked` 和 `deprecation` 警告。 #### 三、最佳实践 尽管 `@SuppressWarnings` 注解可以有效避免编译警告,但在实际开发中,应遵循以下最佳实践: - **...

    6.注解-introdute.doc

    在`SuppressWarningsTest`类中,由于使用了未指定类型的`HashMap`,通常会产生警告,但通过`@SuppressWarnings({"unchecked","deprecation"})`可以忽略这些警告。 4. **自定义注解类型**:你可以通过`@interface`...

    获取Spring中@PathVariable注解里带点的完整参数.doc

    @SuppressWarnings("unchecked") public class WebConfig implements WebMvcConfigurer, WebMvcRegistrations { @Override public RequestMappingHandlerMapping getRequestMappingHandlerMapping() { ...

    JavaAnntation详解.doc

    要查看有关 `@SuppressWarnings` 的详细信息,可以在编译时使用 `-Xlint:unchecked` 参数。 #### 自定义注解 除了内置注解外,Java 还支持自定义注解,即开发者可以根据需要定义新的注解类型。 - **创建注解类型*...

    吴天雄-Java注解及动态性详解.doc

    注解的格式通常以`@注解名`的形式出现在代码中,还可以携带参数,如`@SuppressWarnings(value="unchecked")`。 Java提供了一些内置注解,如: 1. `@Override`:用于标记重写父类方法的方法,编译器会检查该方法是否...

    Spring原理模拟代码

    @SuppressWarnings("unchecked") public ClassPathXmlApplicationContext() throws Exception { SAXBuilder sb = new SAXBuilder(); Document doc = sb.build(this.getClass().getClassLoader() ....

    使用freemarker生成word文档,源代码+jar包+说明文档及注意事项

    @SuppressWarnings("unchecked") public static void createWord(Map dataMap,String templateName,String filePath,String fileName){ try { //创建配置实例 Configuration configuration = new ...

    基于naga开发的TCP客户端/服务器程序

    @SuppressWarnings("unchecked") public TCPServerUnit(String ip, int port) throws ClassNotFoundException { // 注意保持与泛型中的类一致性 super(ip, port,(Class) Class.forName(TCPClientUnit4...

    简单的IoC可以解读基本的xmlBean

    NodeList beanNodes = doc.getElementsByTagName("bean"); for (int i = 0; i < beanNodes.getLength(); i++) { Element beanElement = (Element) beanNodes.item(i); String id = beanElement.getAttribute(...

    springmybatis

    下面对这几个配置文件解释下: 1.Configuration.xml 是 mybatis 用来建立 sessionFactory 用的,里面主要包含了数据库连接相关东西,还有 java 类所对应的别名,比如 <typeAlias alias="User" type="com.yihaomen....

Global site tag (gtag.js) - Google Analytics