[jdk19] RFR: 8290417: CDS cannot archive lamda proxy with useImplMethodHandle

David Holmes dholmes at openjdk.org
Mon Jul 18 03:45:13 UTC 2022


On Mon, 18 Jul 2022 03:15:02 GMT, Ioi Lam <iklam at openjdk.org> wrote:

> Since the impact of this bug can be big, and the fix is simple and low risk (just avoids doing optimizations), I'd like to put this into JDK 19 before RDP2 (Jul 21).
> 
> CDS cannot handle Lambda proxy classes that are generated in the useImplMethodHandle mode. This could happen with classfiles generated by JDK 8 or JDK 11 that access protected methods in a base class from a different package. E.g.,
> 
> 
> class pkg1.Base {
>     protected void doit(String s) {
>         System.out.println(s);
>     }
> }
> class pkg2.Child  extends pkg1.Base {
>     void test() {
>         Optional<String> opt = Optional.of("foo");
>         opt.ifPresent(this::doit);
>     }
> }
> 
> 
> More details of useImplMethodHandle can be found here: https://github.com/openjdk/jdk/blob/522b65743ca10fcba0a27d25b8fa11319999e228/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java#L183-L191
> 
> More details about the condition that triggers the error can be found in the test file Child.jcod.

Looks good!

Thanks.

test/hotspot/jtreg/runtime/cds/appcds/LambdaWithUseImplMethodHandle.java line 28:

> 26:  * @test
> 27:  * @bug 8290417
> 28:  * @summary CDS cannot archive lamda proxy with useImplMethodHandle

typo: lamda -> lambda

test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/DynamicLambdaWithUseImplMethodHandle.java line 28:

> 26:  * @test
> 27:  * @bug 8290417
> 28:  * @summary CDS cannot archive lamda proxy with useImplMethodHandle

typo: lamda -> lambda

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

Marked as reviewed by dholmes (Reviewer).

PR: https://git.openjdk.org/jdk19/pull/146


More information about the core-libs-dev mailing list