RFR: 8071368 Use more concrete types for NamedFunction constants	in the code
    Paul Sandoz 
    paul.sandoz at oracle.com
       
    Fri Feb  5 13:29:52 UTC 2016
    
    
  
Hi Shilpi,
In principle this change is ok, however these methods are kind of special because they are called by code generated from LambdaForms with erased types.
IIUC the casts can serve as belts-and-braces checks just in case that generated code passes something that is not of the correct type. By removing the casts it’s possible to erroneously pass in something of another type that the runtime treats erroneously as if a MethodHandle or MethodType, and then strange things happen. The casts will ordinary be removed by the runtime compiler. By removing them from the Java code it might slightly improve C2 compilation time.
Approval from Vladimir/John would be good.
Paul.
> On 4 Feb 2016, at 13:16, shilpi rastogi <shilpi.rastogi at oracle.com> wrote:
> 
> Hi All,
> 
> Please review the following-
> 
> https://bugs.openjdk.java.net/browse/JDK-8071368
> http://cr.openjdk.java.net/~srastogi/8071368/webrev.02/
> 
> Thanks,
> Shilpi
    
    
More information about the core-libs-dev
mailing list