Draft JEP Announcement: "Computed Constants"
forax at univ-mlv.fr
forax at univ-mlv.fr
Thu Jul 27 17:03:33 UTC 2023
> From: "Brian Goetz" <brian.goetz at oracle.com>
> To: "Remi Forax" <forax at univ-mlv.fr>, "Per-Ake Minborg"
> <per-ake.minborg at oracle.com>
> Cc: "leyden-dev" <leyden-dev at openjdk.org>, "John Rose" <john.r.rose at oracle.com>
> Sent: Thursday, July 27, 2023 6:23:01 PM
> Subject: Re: Draft JEP Announcement: "Computed Constants"
> As Maurizio said, this JEP is a refinement of ideas that were initially explored
> in the "lazy statics" JEP. In a way, this JEP reveals the "lazy statics" JEP as
> skipping a step, jumping to a language and VM when much of the benefit can be
> achieved by a libraries approach. It is possible that at some point, after
> suitable progress and validation, we may decide to take the step of pushing it
> further into the language/VM, but we've made the deliberate choice to push such
> steps into the future.
> In the meantime, there is no reason we cannot have multiple "inconsistent" draft
> or candidate JEPs, so there is no need to "merge" anything right now.
Here is my counter-proposal, use a @Lazy annotation to mark the static final field and requires the static final fields to be initialized by a static method.
With the Logger example, it becomes
class Bar {
// 1. Declare a computed constant value, it has to be initialized by a static method
private static final @Lazy Logger LOGGER = initLogger();
// 2. Initialize the value
private static Logger initLogger() {
return Logger.getLogger("com.foo.Bar");
}
}
You have exactly the same information, it's easier for a class rewriter than the computed constant proposal and a compiler guy and then a VM guy can also work on it.
And obvisouly, it's a backward compatible change.
Rémi
> On 7/27/2023 12:09 PM, Remi Forax wrote:
>> Hello,
>> Are you aware of the lazy static final fields proposal ?
>> [ https://bugs.openjdk.org/browse/JDK-8209964 |
>> https://bugs.openjdk.org/browse/JDK-8209964 ]
>> In think both proposals should be merged.
>> Rémi
>>> From: "Per-Ake Minborg" [ mailto:per-ake.minborg at oracle.com |
>>> <per-ake.minborg at oracle.com> ]
>>> To: "leyden-dev" [ mailto:leyden-dev at openjdk.org | <leyden-dev at openjdk.org> ]
>>> Sent: Thursday, July 27, 2023 5:52:46 PM
>>> Subject: Draft JEP Announcement: "Computed Constants"
>>> Hi all,
>>> Maurizio and I have drafted a JEP for computed constants, which are
>>> immutable value holders that are initialized at most once. They offer
>>> the performance and safety benefits of final fields while offering
>>> greater flexibility as to the timing of initialization. In the
>>> context of Leyden, they could be one basis for shifting computation
>>> both forward and backward in time.
>>> The draft is here: [ https://openjdk.org/jeps/8312611 |
>>> https://openjdk.org/jeps/8312611 ]
>>> Now that the Leyden repo is open, I’ll publish the prototype code to a
>>> new branch there shortly.
>>> Comments are welcome!
>>> Best, Per
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.org/pipermail/leyden-dev/attachments/20230727/37d75afa/attachment.htm>
More information about the leyden-dev
mailing list