Details
-
Enhancement
-
Resolution: Fixed
-
P3
-
None
-
b22
Backports
Issue | Fix Version | Assignee | Priority | Status | Resolution | Resolved In Build |
---|---|---|---|---|---|---|
JDK-8245771 | 13.0.4 | Vojin Jovanovic | P3 | Resolved | Fixed | b03 |
JDK-8233803 | 11.0.7-oracle | Vojin Jovanovic | P3 | Resolved | Fixed | b01 |
JDK-8236185 | 11.0.7 | Jie Kang | P3 | Resolved | Fixed | b01 |
JDK-8233133 | 11.0.5.0.50-oracle | Mark Reinhold | P3 | Closed | Fixed | b01 |
Description
We would like to introduce a flag `jdk.internal.lambda.eagerlyInitialize`, which is `true` by default, and that can be used to prevent the eager initialization of lambdas. The proposed solution is summarised in the two following commits:
1) Introduces a new shape of non-capturing lambdas, where the lambda instance is kept in a static field:
https://github.com/graalvm/labs-openjdk-11/commit/00b9ecd85dedd0411837eee33635dd83e8b7def8
2) Introduces the conditional initialization of lambdas as a pure performance optimization:
https://github.com/graalvm/labs-openjdk-11/commit/273e8590a7b57c0c10d9213ca9e0ba581e2817b8
With the proposed scheme we get simpler code, that can be used for heap snapshotting and 1.5% better startup time for `HelloLambda.java`. The detailed numbers follow.
For all the tests we used the same configuration: `Intel(R) Xeon(R) CPU E5-2690 v4 @ 2.60GHz` bound to a single socket with turbo disabled. We measured the Java 11 master (master), Java 11 with the first patch (patched) and Java 11 with the patch and lambdas pre-initialized with Unsafe (patched-init). For the instructions count, we used `perf stat` and executed 3 times a 100 runs and took the average. The standard deviation is very small for the interpreter case so I don’t report it. Here are the results:
(1) I measured only the number of instructions due to the OS noise related to time. The "Hello, Lambda!" numbers are with the JIT enabled.
| Branch | Instructions |
|-----------------|--------------------|
| master | 500,490,396 |
| patched | 492,933,691 |
| patched-init | 483,938,234 |
(2) The instruction count is measured in the interpreter (-Xint) and JIT and the time is measured only with the JIT enabled:
| Branch | Instructions (-Xint) | Instructions (JIT) | Time in us (JIT)|
|------------------|--------------------------|-------------------------|---------------------|
| master | 1,285,945,379 | 1,922,974,572 | 227,837 |
| patched | 1,315,914,375 | 2,058,175,796 | 233,457 |
| patched-init | 1,286,079,726 | 1,986,969,597 | 218,579 |
Attachments
Issue Links
- backported by
-
JDK-8233803 Introduce a system property to disable eager lambda initialization
- Resolved
-
JDK-8236185 Introduce a system property to disable eager lambda initialization
- Resolved
-
JDK-8245771 Introduce a system property to disable eager lambda initialization
- Resolved
-
JDK-8233133 Introduce a system property to disable eager lambda initialization
- Closed
- csr for
-
JDK-8233090 Introduce a system property to disable eager lambda initialization
- Closed
- relates to
-
JDK-8242451 ensure semantics of non-capturing lambdas are preserved independent of execution mode
- Resolved