RFR: 8345836: stable annotation documentation is incomplete

Roger Riggs rriggs at openjdk.org
Tue Dec 10 14:56:01 UTC 2024


On Mon, 9 Dec 2024 23:53:31 GMT, John R Rose <jrose at openjdk.org> wrote:

> The javadoc for jdk.internal.vm.annotation.Stable is incomplete.
> 
> The existing documentation gives an over-simple user model,
> and does not explain how it is implemented.
> Proposed new documentation will detail how the annotation
> is implemented, and how it may be used correctly.
> 
> The improved documentation will makes it easier for JDK programmers
> to use the annotation more aggressively, and more confidently.
> 
> This is a first cut.  Please comment…

src/java.base/share/classes/jdk/internal/vm/annotation/Stable.java line 130:

> 128:  * any other context.  This implies that a constructor may choose to
> 129:  * initialize a stable variable, rather than "leaving it for later",
> 130:  * and that initial will be safely published, as if the field were

"initial" -> "initial value"

src/java.base/share/classes/jdk/internal/vm/annotation/Stable.java line 165:

> 163:  * <p>
> 164:  * After constant folding, the compiler can make use of may aspects of
> 165:  * the object: Its dynamic type, its length (if it is an array), and

"Its" -> "its". (no capital I needed)

src/java.base/share/classes/jdk/internal/vm/annotation/Stable.java line 215:

> 213:  * some other internal proof of correctness (accounting for any
> 214:  * possible racing API access), or by some appropriate disclaimer in
> 215:  * the API about undefined behavior.

This caution/warning might be better at the top of the file.

-------------

PR Review Comment: https://git.openjdk.org/leyden/pull/26#discussion_r1878235640
PR Review Comment: https://git.openjdk.org/leyden/pull/26#discussion_r1878240903
PR Review Comment: https://git.openjdk.org/leyden/pull/26#discussion_r1878249158


More information about the leyden-dev mailing list