Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-8314454

Clarify the name of the declaring class of StackTraceElement

XMLWordPrintable

    • Icon: CSR CSR
    • Resolution: Approved
    • Icon: P4 P4
    • 22
    • core-libs
    • None
    • behavioral
    • minimal
    • Specification clarification to match the long-standing behavior.
    • Java API
    • SE

      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.
            *

            mchung Mandy Chung (Inactive)
            mchung Mandy Chung (Inactive)
            Alan Bateman
            Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

              Created:
              Updated:
              Resolved: