13、Java 9 新特性 – 增强 @Deprecated 注解

@Deprecated 注解很早就存在了,如果我记得没错的话,好像是 Java 5 ( 后来我去查了资料,也的确是 Java 5 就引入了 ) 。

一个使用 @Deprecated 注解的元素,无论是一个类或是一个方法,可能是由以下原因导致了不应该再使用它

1、 使用它可能会导致错误;
2、 在未来的版本中不被兼容;
3、 在未来的版本中可能会被删除;
4、 存在更好的更有效的替代方法;

如果一个程序或代码片段使用了 @Deprecated 注解的元素,那么编译器就会生成一个警告信息,表明这个元素是不被推荐使用的。

我们都一直延续了这样的习惯好久,直到 Java 9 的发布,我才发现 @Deprecated 注解还可以做的更好

Java 9 对 @Deprecated 注解做了两项重要的增强。

1、 forRemoval–指示在将来的版本中是否要删除带注解的元素默认值为false
2、 since–返回注解元素刚添加@Deprecated注解的版本;

一看不知道,看了很吃惊,这两个属性,还是蛮有作用的

@Deprecated 的 since 属性

since 的使用,你可以查阅 Java 9 的官方文档中 Boolean 类型的文档,在该文档中演示了如何在 @Deprecated 注解上使用 since 属性

文档地址 https://docs.oracle.com/javase/9/docs/api/java/lang/Boolean.html#Boolean-boolean-

可以看到下图中粉色框框的内容

*

@Deprecated 的 forRemoval 属性

关于@DeprecatedforRemoval 属性的使用,可以查看官方提供的文档中的有关 System 类的部分,该部分演示了 @Deprecated 注解使用 forRemoval 属性

文档地址 https://docs.oracle.com/javase/9/docs/api/java/lang/System.html#runFinalizersOnExit-boolean-

可以看到下图中粉色框框的内容

*