Summary
Clarify the specification of StackTraceElement::getClassName
and the
declaringClass
parameter of the StackTraceElement
constructor be
the binary name of the class containing the execution point represented
by this stack trace element.
Problem
The specification of StackTraceElement
refers the class name as the
fully qualified name but it should be the binary name.
Solution
Update the specification of StackTraceElement::getClassName
and the
declaringClass
parameter of the StackTraceElement
constructor be
the binary name instead of fully qualified class name.
Specification
diff --git a/src/java.base/share/classes/java/lang/StackTraceElement.java b/src/java.base/share/classes/java/lang/StackTraceElement.java
index fc39291b316..9b87d2ae7cd 100644
--- a/src/java.base/share/classes/java/lang/StackTraceElement.java
+++ b/src/java.base/share/classes/java/lang/StackTraceElement.java
@@ -102,8 +102,9 @@ public final class StackTraceElement implements java.io.Serializable {
* #getModuleVersion module version} of the stack trace element will
* be {@code null}.
*
- * @param declaringClass the fully qualified name of the class containing
- * the execution point represented by the stack trace element
+ * @param declaringClass the {@linkplain ClassLoader##binary-name binary name}
+ * of the class containing the execution point represented by
+ * the stack trace element
* @param methodName the name of the method containing the execution point
* represented by the stack trace element
* @param fileName the name of the file containing the execution point
@@ -137,8 +138,9 @@ public final class StackTraceElement implements java.io.Serializable {
* @param moduleVersion the module version if the class containing the
* execution point represented by the stack trace is in a named
* module that has a version; otherwise {@code null}
- * @param declaringClass the fully qualified name of the class containing
- * the execution point represented by the stack trace element
+ * @param declaringClass the {@linkplain ClassLoader##binary-name binary name}
+ * of the class containing the execution point represented by
+ * the stack trace element
* @param methodName the name of the method containing the execution point
* represented by the stack trace element
* @param fileName the name of the file containing the execution point
@@ -249,11 +251,9 @@ public final class StackTraceElement implements java.io.Serializable {
}
/**
- * Returns the fully qualified name of the class containing the
- * execution point represented by this stack trace element.
- *
- * @return the fully qualified name of the {@code Class} containing
- * the execution point represented by this stack trace element.
+ * {@return the {@linkplain ClassLoader##binary-name binary name}
+ * of the {@code Class} containing the execution point represented
+ * by this stack trace element}
*/
public String getClassName() {
return declaringClass;
@@ -332,7 +332,7 @@ public final class StackTraceElement implements java.io.Serializable {
* the name of the class loader. The second element "{@code foo@9.0}"
* is the module name and version. The third element is the method
* containing the execution point; "{@code com.foo.Main"}" is the
- * fully-qualified class name and "{@code run}" is the name of the method.
+ * binary name and "{@code run}" is the name of the method.
* "{@code Main.java}" is the source file name and "{@code 101}" is
* the line number.
*
- csr of
-
JDK-8314449 Clarify the name of the declaring class of StackTraceElement
-
- Resolved
-