[lworld] Dropping jdk.incubator.mvt and MVT change in MethodHandle and reflection

Karen Kinnear karen.kinnear at oracle.com
Tue Feb 27 18:14:45 UTC 2018



> On Feb 27, 2018, at 12:33 PM, mandy chung <mandy.chung at oracle.com> wrote:
> 
> Hi Karen,
> 
> On 2/27/18 9:20 AM, Karen Kinnear wrote:
>> Mandy,
>> 
>> Many thanks for doing these changes!
>> 
>> I had a couple of questions on the source changes:
>> 
>> 1) java/lang/invoke/MethodType.java
>>   leadingReferenceParameter()
>> 
>> The way we are modeling this, a value type is a reference. It sometimes requires
>> special handling - like arrays or interfaces do - but it is still a subtype of java.lang.Object, so still a reference.
>> 
>> I am not sure of the uses of leadingReferenceParameter - but I would expect it to
>> only throw an exception for primitives.
> 
> This patch is the first pass to clean up lworld branch.   leadingReferenceParameter change is simply reverting back to the default branch version.   I will have to look into how MethodHandle and VarHandles work with values in the next pass.   I did change core reflection to throw IAE when setting fields in values as they are immutable.   Basically I try to do this in a few patches. 
Totally makes sense to do this in multiple steps.

I think the leadingReferenceParameter change is not just a reversion - I think you added a
|| type.isValue() - which I think is incorrect.

> 
>> 2) java/lang/invoke/MethodHandles.java
>> 
>> There should be no constructor for value types. 
>> I believe Srikanth is ensuring that in javac, and the jvm will be ensuring that at runtime.
>> So maybe that means that no constructor will be found.
>> 
>> Would it make sense for findConstructor to check for isValue and throw NoSuchMethodException
>> directly? Or does that fall out of the ResolveOrFail call?
Thank you to John for the correction - my bad - value types have no <init>, they do have constructors.
So ignore my comment here.
> 
> I leave MethodHandle support in the next iteration.   Sorry I should have made this clear in my message.   Are you okay with dropping MVT first and handle MHs and tests subsequently?
Absolutely - doing this incrementally is a good way to go.

thanks,
Karen
> 
> 
> Mandy
>> It would be good to have an explicit test for this if you are collecting test cases.
>> 
>> thanks,
>> Karen
>> 
>> 
>> 
>>> On Feb 23, 2018, at 11:45 AM, mandy chung <mandy.chung at oracle.com> <mailto:mandy.chung at oracle.com> wrote:
>>> 
>>> http://cr.openjdk.java.net/~mchung/valhalla/webrevs/lworld-drop-mvt <http://cr.openjdk.java.net/~mchung/valhalla/webrevs/lworld-drop-mvt>
>>> 
>>> This is the first pass to remove jdk.incubator.mvt module and
>>> MVT support in MethodHandle and reflection.  I have also added
>>> Class::isValue method to determine if it's a value class.  Fields
>>> of a value class are immutable and Field::setXXX methods will
>>> throw IAE if the declaring class is a value class.
>>> 
>>> Mandy
>>> 
> 




More information about the valhalla-dev mailing list