Never use deprecated fields, methods, or classes in new code. The Java SE 6 documentation provides a complete list of deprecated APIs [[API 2006]]. Java also provides a @deprecated
annotation to indicate the deprecation of specific fields, methods, and classes. For instance, many methods of java.util.Date
, such as Date.getYear()
, have been explicitly deprecated. Rule THI05-J. Do not use Thread.stop() to terminate threads describes issues that can result from using the deprecated Thread.stop()
method.
Obsolete fields, methods, and classes should not be used. Java lacks any annotation that indicates obsolescence; nevertheless, several classes and methods are documented as obsolete. For instance, the java.util.Dictionary
class is marked as obsolete; new code should use java.util.Map<K,V>
instead [[API 2006]].
Obsolete Methods and Classes
The following methods and classes must not be used:
Class or Method |
Replacement |
Rule |
---|---|---|
|
|
|
|
|
|
|
|
|
|
|
ERR06-J. Do not let code throw undeclared checked exceptions |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The Java Virtual Machine (JVM) Profiler Interface (JVMPI) and JVM Debug Interface (JVMDI) are also deprecated and have been replaced by the JVM Tool Interface (JVMTI). See rule ENV05-J. Do not deploy an application that can be remotely monitored for more information.
Risk Assessment
Using deprecated or obsolete classes or methods in program code can lead to erroneous behavior.
Rule |
Severity |
Likelihood |
Remediation Cost |
Priority |
Level |
---|---|---|---|---|---|
MET02-J |
high |
likely |
medium |
P18 |
L1 |
Automated Detection
Detecting uses of deprecated methods is straightforward. Obsolete methods and thread-unsafe methods have no automatic means of detection.
Related Guidelines
<ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="1dcbee31-da35-4b53-83f5-226e4c51de0d"><ac:plain-text-body><![CDATA[ |
[ISO/IEC TR 24772:2010 |
http://www.aitcnet.org/isai/] |
Deprecated language features [MEM] |
]]></ac:plain-text-body></ac:structured-macro> |
CWE-589. Call to non-ubiquitous API |
Bibliography
<ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="0c518287-3e1b-49ef-b5de-0821db6f8714"><ac:plain-text-body><![CDATA[ |
[[API 2006 |
AA. References#API 06]] |
[Deprecated API |
http://java.sun.com/javase/6/docs/api/deprecated-list.html], [Dictionary |
http://download.oracle.com/javase/6/docs/api/java/util/Dictionary.html] |
]]></ac:plain-text-body></ac:structured-macro> |
<ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="7e04bb24-e8f5-4188-9d13-da2b40bda5f6"><ac:plain-text-body><![CDATA[ |
[[SDN 2008 |
AA. References#SDN 08]] |
Bug database, [Bug ID 4264153 |
http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4264153] |
]]></ac:plain-text-body></ac:structured-macro> |