Initial webrev with changes for JDK 9

Paul Sandoz paul.sandoz at oracle.com
Fri Mar 11 21:09:31 UTC 2016


> On 11 Mar 2016, at 18:53, Alan Bateman <Alan.Bateman at oracle.com> wrote:
> 
> On 11/03/2016 16:50, Paul Sandoz wrote:
>> :
>> I browsed the code. Generally the feeling i get is it’s of good quality. Previously some of this area was quite legacy and it is refreshing to view more modern code.
> Thanks for going through it. There is quite a mix here, lots of new code but lots of ancient code has to be changed along the way.
> 
>> 
>> Comments below, only the first is something i think we should really change, the others are up to you.
>> 
>> Once Jigsaw goes in i wonder if we should opportunistically revisit the use of URL and Enumeration with class loaders?
> Potentially, it's just hasn't been interesting so far because the legacy ClassLoader methods aren't specified to locate resources in modules.
> 

Understand. Just looking for opportunities to "rm Enumeration" and potentially improve how URIs are processed by encouraging the use of “java.net.URI” instead of “java.net.URL” (even if one has to transform the former to the latter to open a connection).


> 
>> :
>> 
>> 
>> The method getResourceAsStream has an optimisation for a BuiltinClassLoader:
>> 
>> :
>> 
>> Is that something you plan to include for getResource too at some point?
> getResource returns a URL so the optimization to avoid the going through the URL protocol handler isn't applicable.
> 

Ok.


> 
>> 
>> If you can syncrhonize on this, just use double checked locking?
> I'll look at it, part of the reason for the currently implementation is that we were setting several fields.
> 

AFAICT it only CAS’es one field.


> 
>> 
>> 
>> 
>> j.l.i.BoundMethodHandle
>>>> 
>>  791                 // ## FIXME
>>  792                 // assert F_SPECIES_DATA.getDeclaredAnnotation(Stable.class) != null;
>> 
>> That’s odd. Why did that need commenting out?
> getDeclarationAnnotation => annotation parsing and creating proxies and too early in the VM startup for that. It was commented out in one of the numerous sync ups I think.
> 

Ah!


> I'll ask a comment to it.
> 
> 
>> 
>> 
>> MethodHandles
>>>> 
>> That’s quite some trick to create PUBLIC_LOOKUP :-) spinning up a new class (“Unamed”) in a new class loader. If that mechanism is gonna stay and If there are costs associated with that, we could easily skip the ASM part and use hard coded bytes.
> I think TBD, I think John would like PL to revert to using Object as the lookup class but requires extending the lookup modes. I have an issue in JIRA to track another phase of work here.
> 

Ok. This is a gnarly area.

Paul.


More information about the jigsaw-dev mailing list