在部落格文章《 應用JDK 9 @Deprecated增強功能》中 ,我讨論了JDK 9中 @Deprecated批注中對forRemoval()和since()可選元素(方法)的添加 。 我在那篇文章中說:“在Java SE API上應用新的JDK 9 @Deprecated方法也可以指導如何使用它們。” 在本文中,我将研究增強的
@Deprecated
批注對JDK類java.util.Observable的應用 。
幾乎從一開始就存在
java.util.Observable
類(自Java 1.0起)。 從JDK 9開始,它将被标記為已棄用。 以下螢幕快照顯示了Web浏覽器中此類的Javadoc表示形式的一部分。

這是我上一篇博文中描述的 “不建議删除計劃”類别中的一個類的示例。
since()
的存在提供了有關何時不推薦使用的資訊(JDK 9),而缺少
forRemoval()
表明缺少具體的計劃來實際删除該類。 還以類似的方式棄用了java.util.Observer接口 ,并且其文檔引用了
Observable
類的文檔。
Observable
文檔不僅在不推薦使用時進行中繼,而且還記錄了
Observable
的問題,這些問題使不推薦使用,并提供了有關可能使用的替代方案的重要資訊,而不是
Observable
:
此類和Observer接口已被棄用。 Observer和Observable支援的事件模型非常有限,Observable傳遞的通知順序未指定,并且狀态更改與通知不一一對應。 對于更豐富的事件模型,請考慮使用java.beans包。 為了線上程之間進行可靠且有序的消息傳遞,請考慮使用java.util.concurrent包中的并發資料結構之一。 有關React式流樣式的程式設計,請參見Flow API。
這是一個很好的示例,說明Java開發人員如何使用Javadoc标記
@deprecated
來提供與棄用相關的更詳細的資訊,即使使用增強的
@Deprecated
注釋也無法提供。 JEP 277 (“增強的棄用”)明确列出了統一的Javadoc标簽
@deprecated
和注釋
@Deprecated
為“非目标”:“該項目的目标不是将@deprecated的Javadoc标簽與@Deprecated注釋統一。 ”
可以棄用
Observable
和
Observer
其他詳細資訊可以在JDK-8154801中找到(“棄用Observer和Observable”)。 Josh Bloch 于1999年2月發表了一個引用,作為JDK-4180466的一部分(“為什麼java.util.Observable類無法序列化。”):
此類不再處于積極開發中。 它在JDK中基本上未使用,并且在大多數情況下已被1.1 Beans / AWT事件模型取代。 …可觀察性已被廢棄,并且不再活躍。
在大多數情況下,似乎
Observer
和
Observable
的使用并不多 ,是以棄用不應該是一個大問題,尤其是考慮到沒有明确的計劃将其完全删除時。
翻譯自: https://www.javacodegeeks.com/2017/05/javas-observer-observable-deprecated-jdk-9.html