java Lint 工具(JDK1.5环境下的 -Xlint:unchecked 的解决方式)
来源:互联网 发布:傲剑坐骑数据 编辑:程序博客网 时间:2024/05/01 07:04
*目录* 1. 简介 2. Lint 3. Java Lint 选项
1. 简介
如果你已经开始使用 JDK 1.5(或者称为 JDK 5.0),那么你很可能在编译时,已经看到过类似如下的警告信息:
注意: E:/sandbox/src/DefaultController.java 使用或覆盖了已过时的 API。
注意: 要了解详细信息,请使用 -Xlint:deprecation 重新编译。
或者这个:
注意: E:/sandbox/src/DefaultController.java 使用了未经检查或不安全的操作。
注意: 要了解详细信息,请使用 -Xlint:unchecked 重新编译。
这些警告不难理解。如果愿意,只要按照提示在编译时指定相应的选项就可以了。可是,如果你也像我一样,困惑于这个编译选项中晦涩的英文(-Xlint),以至于 经常要借助参考手册才能想起这个选项的用词或者拼写,那么这篇短文或许对你有些帮助。
2. Lint
在介绍这些关于警告的选项前,我们先看看 lint 究竟是什么。在英文中,lint
是指纠缠在一起的细小纤维或者绒毛,比如衣物上面起的毛或者线头。咋看起来,这个词用在 Java
编译器选项中,似乎有点风马牛不相及。但是如果你知道一个古老的 Unix 工具被命名为 lint(1),那就另当别论了。
在 Unix 中,实用工具 lint(1)
用于在对程序编译的过程中,对程序进行更为细致的额外检查,比如使用未经初始化的变量等常见的编程问题。如此命名该工具,正是借用了"lint"
一词的含义:将"lint"从程序中挑拣出来,从而使程序更"干净"。
现在我们至少对选项中的 "lint" 有了一些有趣的认识了,记住这个词应该问题不大了。随后,我们将简单地了解一下 Java 的 lint
工具。当然,因为 lint 工具当然会涉及到语言规范中的一些知识,而这篇短文显然不适合阐述这些知识。如果对相关内容有兴趣,可以参考其它资料。
3. Java Lint 选项
Java 编译器的选项包括所谓的标准选项和非标准选项。标准选项是指在当前版本的开发环境中支持,且在未来版本中也将被支持的选项。常用的标准选项比如
-classpath 以及 -d 等等。
非标准选项是在当前版本的开发环境中支持,但不能保证将来一定会继续支持的选项。非标准选项都由 -X 开头,比如我们这里所关心的 Java Lint
选项都由 -Xlint 开头。需要先说明的是,单纯的选项 -X 本身是一个标准选项,作用是显示关于非标准选项的信息。参考这个例子:
E:/>javac -X
-Xlint 启用建议的警告
-Xlint:{all,deprecation,unchecked,fallthrough,path,serial,finally,-deprecat ion
,-unchecked,-fallthrough,-path,-serial,-finally}启用或禁用特定的警告
-Xbootclasspath/p:<路径> 置于引导类路径之前
-Xbootclasspath/a:<路径> 置于引导类路径之后
-Xbootclasspath:<路径> 覆盖引导类文件的位置
-Djava.ext.dirs=<目录> 覆盖安装的扩展目录的位置
-Djava.endorsed.dirs=<目录> 覆盖签名的标准路径的位置
-Xmaxerrs <编号> 设置要输出的错误的最大数目
-Xmaxwarns <编号> 设置要输出的警告的最大数目
-Xstdout <文件名> 重定向标准输出
这些选项都是非标准选项,如有更改,恕不另行通知。
我们依次来看看其中涉及 lint 的选项:
-Xlint
启用所有警告。该选项相当于 -Xlint:all 选项。相反,关闭所有警告的选项为 -Xlint:none。
-Xlint:unchecked
启用对所谓的未经检查的转换(unchecked warning)的警告。这个警告涉及 JDK 5.0 中的新特性——范型(Generic
Type),这绝对是另外一个故事了。有兴趣的话,可以在 Internet 上搜索到很多关于范型的文章。
-Xlint:path
当发现不存在的路径或者目录时给出警告,比如标准选项中的类路径(classpath),源代码路径(sourcepath)等等。
-Xlint:serial
当在可序列化的类中没有发现 serialVersionUID 的定义时,给出警告。
Xlint:finally
当发现 finally 子句无法正常结束的情况时给出警告。比如下面这段代码:
try {
} finally {
for (;;);
}
当在 switch 语句块中发现 fall-through 的情形时给出警告。这里所说的 fall-through 情形指的是在
switch语句块中,除了最后一个
case 之外的其它 case 中没有包含 break 语句,导致执行代码时从一个 case 直接穿过执行到了下一个 case 中。比如下面这段代码:
switch (color) {
case GREEN:
System.out.println("green");
// 没有 break 语句;fall-through
case RED:
System.out.println("red");
break;
case YELLOW:
System.out.println("yellow");
显示关于使用了过时的 API 的详细信息。这个选项等同于一个我们熟悉的标准选项,即 -deprecation 选项。相对其它 lint
选项而言,该选项的特别之处在于,即使你关闭了它,编译器仍然会简单地提醒你某个类中使用了过时的 API。只是启用该项警告时,显示的信息将更详细而以。
上面提到的这些 lint 选项中的警告名称(冒号后面的部分),可以加以组合,从而有选择的开启或者关闭特定的一组 lint 警告选项,比如
-Xlint:deprecation,
finally 表示开启 deprecation 和 finally 警告。还可以在警告名称前加上"-"表示关闭该项警告,比如
-Xlint:all,-unchecked 表示开启除了 unchecked 之外的所有警告。
- Java Lint 工具(JDK1.5环境下的 -Xlint:unchecked 的解决方式)
- java Lint 工具(JDK1.5环境下的 -Xlint:unchecked 的解决方式)
- Ant : -Xlint:unchecked 和 - encoding 的 解决方式
- Linux下运行java文件出现 -Xlint:unchecked
- -Xlint:unchecked
- -Xlint:unchecked
- -Xlint:unchecked
- pc-lint静态代码分析工具(检查linux下C++代码的实现方式)
- 《Maven-编译错误解决》---请使用 -Xlint:unchecked 重新编译
- Eclipse中报错“要了解详细信息,请使用-xlint:unchecked重新编译”的解决方案
- 用ant执行时报错“要了解详细信息,请使用-xlint:unchecked重新编译”的解决方案
- java 泛型 编译警告:使用了未经检查或不安全的操作。 注: 有关详细信息, 请使用 -Xlint:unchecked 重新编译。
- java -Xlint:uncecked和@SuppressWarning("unchecked") 基础使用
- java下的printf(jdk1.5+)
- ArrayListTest编译问题:使用了未经检查或不安全的操作;请使用 -Xlint:unchecked 重新编译
- Hashtable与ArrayListTest编译问题:使用了未经检查或不安全的操作;请使用 -Xlint:unchecked 重新编译
- android lint工具的使用
- Android工具:Lint的使用
- BZOJ 3456 城市规划 多项式求ln
- 谈谈dynamic_cast函数。
- SVN的下载、安装、配置和常用操作
- 不要让“知识”限制了你的思维
- Android数据库安全解决方案,使用SQLCipher进行加解密
- java Lint 工具(JDK1.5环境下的 -Xlint:unchecked 的解决方式)
- 99行拓扑优化 代码解析
- 网络连接之——谷歌提供的通信框架Volley【避免创建多个线程对象】
- 使用查询结果产生的数据批量执行update 或add sql语句
- ViewPager嵌套Fragment来回滑动重新加载数据
- OVM Concept: Oracle VM Agent
- android手机客户端上传文件,java servlet服务器端接收并保存到服务器
- keepalived工作原理和配置说明
- Bootstrap栅格布局的注意事项