@SuppressWarnings学习笔记


前言

例在学习fail-fast与fail-safe之中看到了@SuppressWarnings。
经过搜索与学习,写下了一篇学习笔记。


一、@SuppressWarnings是什么?

suppress
英 [səˈpres] 美 [səˈpres]
vt.
镇压;(武力)平定;压制;禁止(发表);查禁;封锁;抑制;控制;忍住

合起来
意思就是镇压警告,抑制警告

引言2:
注释类型:
    当你的编码可能存在警告时,比如安全警告,可以用它来消除。

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

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

在java编译过程中会出现很多警告,有很多是安全的,但是每次编译有很多警告影响我们对error的过滤和修改,我们可以在代码中加上 @SuppressWarnings(“XXXX”) 来解决

例如:@SuppressWarnings(“deprecation”) 表示不显示使用了不赞成使用的类或方法时的警告。

再比如:

编码时我们总会发现如下:变量未被使用的警告提示
  在这里插入图片描述

二、 @SuppressWarings注解

1.引入库

作用:用于抑制编译器产生警告信息。

    示例1——抑制单类型的警告:
        @SuppressWarnings("unchecked")
        public void addItems(String item){
            @SuppressWarnings("rawtypes")
            List items = new ArrayList();
            items.add(item);
        }

    示例2——抑制多类型的警告:
        @SuppressWarnings(value={"unchecked", "rawtypes"})
        public void addItems(String item){
            List items = new ArrayList();
            items.add(item);
        }

    示例3——抑制所有类型的警告:
        @SuppressWarnings("all")
        public void addItems(String item){
            List items = new ArrayList();
            items.add(item);
        }

三、注解目标

通过 @SuppressWarnings 的源码可知,其注解目标为类、字段、函数、函数入参、构造函数和函数的局部变量。
  而专家建议注解应声明在最接近警告发生的位置。

四、抑制警告的关键字

It depends on your IDE or compiler.

Here is a list for Eclipse Galileo:

all to suppress all warnings
boxing to suppress warnings relative to boxing/unboxing operations
cast to suppress warnings relative to cast operations
dep-ann to suppress warnings relative to deprecated annotation
deprecation to suppress warnings relative to deprecation
fallthrough to suppress warnings relative to missing breaks in switch statements
finally to suppress warnings relative to finally block that don’t return
hiding to suppress warnings relative to locals that hide variable
incomplete-switch to suppress warnings relative to missing entries in a switch statement (enum case)
nls to suppress warnings relative to non-nls string literals
null to suppress warnings relative to null analysis
restriction to suppress warnings relative to usage of discouraged or forbidden references
serial to suppress warnings relative to missing serialVersionUID field for a serializable class
static-access to suppress warnings relative to incorrect static access
synthetic-access to suppress warnings relative to unoptimized access from inner classes
unchecked to suppress warnings relative to unchecked operations
unqualified-field-access to suppress warnings relative to field access unqualified
unused to suppress warnings relative to unused code
List for Indigo adds:

javadoc to suppress warnings relative to javadoc warnings
rawtypes to suppress warnings relative to usage of raw types
static-method to suppress warnings relative to methods that could be declared as static
super to suppress warnings relative to overriding a method without super invocations
List for Juno adds:

resource to suppress warnings relative to usage of resources of type Closeable
sync-override to suppress warnings because of missing synchronize when overriding a synchronized method
部分翻译如下:

@SuppressWarnings(“unchecked”)   // 抑制未检查的转化,例如集合没有指定类型的警告
  @SuppressWarnings(“unused”)    // 抑制未使用的变量的警告
  @SuppressWarnings(“resource”)    // 抑制与使用Closeable类型资源相关的警告
  @SuppressWarnings(“path”)      // 抑制在类路径,原文件路径中有不存在的路径的警告
  @SuppressWarnings(“deprecation”) // 抑制使用了某些不赞成使用的类和方法的警告
  @SuppressWarnings(“fallthrough”) // 抑制switch语句执行到底没有break关键字的警告
  @SuppressWarnings(“serial”)    // 抑制某类实现Serializable,但是没有定义serialVersionUID,这个需要但是不必须的字段的警告
  @SuppressWarnings(“rawtypes”) // 抑制没有传递带有泛型的参数的警告
  @SuppressWarnings(“all”)    // 抑制全部类型的警告


PS:

https://cloud.tencent.com/developer/article/1353329(更详细)
部分摘录,侵联删

  • 11
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值