<div dir="ltr">Hello,<div>I came across JDK-8246634, which proposed to add MethodHandles.Lookup.ensureInitialized to ensure a class is initialized before a Method Handle is invoked. However, this appears to be contrary to what project Leyden is aiming for. Explicit class initializations are mostly a hurdle to condensing computations to be available before JVM startup.</div><div><br></div><div>Thus, I wonder if such an API addition is worth exploring. In the original RFE JDK-8235521, the main usages of ensureClassInitialized was barrier for static field accessors in MH (and now VH) and to ensure the side effects are performed by class initializers (as in SharedSecrets).</div><div><br></div><div>Since it seems Project Leyden has done extensive research on class initialization patterns, I wonder if there are any other purposes for the ensureClassInitialized or Class.forName APIs (which performs explicit initialization), and how Leyden treats them for condensing. Such information would be helpful for deciding about the ensureInitialized for Method Handle API.</div><div><br></div><div>Please don't hesitate to reply if you have other remarks about this RFE.</div><div><br></div><div>Best,</div><div>Chen Liang</div></div>