警告
在android开发中,我们在运行程序时,编译Build窗口中的信息中有时会出现如下-Xlint:deprecation的信息提示
makefile
注: 某些输入文件使用或覆盖了已过时的 API。
注: 有关详细信息, 请使用 -Xlint:deprecation 重新编译
原因
根据提示信息:我们在写代码时,调用了一些已过时的api(也就是标记有@Deprecated
注解的方法)
也就是当前SDK比较新,然而我们使用了一些比较旧api,这些旧api在当前SDK中已经有新的api替代
如:
解决
我们在gradle的构建脚本中添加编译-Xlint:deprecation
的参数
javascript
allprojects {
gradle.projectsEvaluated {
tasks.withType(JavaCompile) {
options.compilerArgs << "-Xlint:deprecation"
}
}
}
可以在子模块的build.gradle文件中进行添加。
添加完后,再次运行程序,编译日志中就可以看到,我们使用了哪些过时的api
我们可以点击进入到警告的代码,采用使用本SDK中新api替代过时api,消除警告。
比如这里是
我们调用Html.fromHtml("<b>test</>");
这个方法,fromHtml(String)
这个api在本SDK中已经过时了,我们可以ctrl + 鼠标左键进入fromHtml(String)
这个方法中,看它的方法描述
他的建议信息是@deprecated use {@link #fromHtml(String, int)} instead.
也就是建议我们使用fromHtml(String source, int flags)
这个api
我们改用fromHtml(String source, int flags)
这个api,警告就消除了。
扩展
与-Xlint:deprecation
设置类似的,还有-Xlint:unchecked
这个编译参数
makefile
注: G:\LHY\android-java-Demo\app\src\main\java\com\example\mydemo\MainActivity.java
使用了未经检查或不安全的操作。
注: 有关详细信息, 请使用 -Xlint:unchecked 重新编译。
如提示所说的,我们在写代码的时候没有注意规范
同样的,我们也可以在gradle构建脚本中加上-Xlint:unchecked
这个编译参数
javascript
allprojects {
gradle.projectsEvaluated {
tasks.withType(JavaCompile) {
// -Xlint:unchecked 日志打印'未经检查或不安全的操作'的详细信息
// -Xlint:deprecation 日志打印`输入文件使用或覆盖了已过时的 API`的详细信息
options.compilerArgs << "-Xlint:unchecked" << "-Xlint:deprecation"
}
}
}
重新编译
可以看到,我们写如下代码出现的警告
java
Map<String, String> map = new HashMap();
我们按规范修改如下
arduino
Map<String, String> map = new HashMap<>();
再次编译,警告就消除了