boxing + unboxing a VT is not a no-op ?
Tobias Hartmann
tobias.hartmann at oracle.com
Mon Jul 16 14:16:51 UTC 2018
Thanks Remi!
When trying to re-produce, I'm hitting JDK-8207346. I'll fix that first and then investigate the
performance issue.
Tobias
On 13.07.2018 15:11, forax at univ-mlv.fr wrote:
> the source code is here:
> https://github.com/forax/valuetype-lworld/blob/master/src/test/java/fr.umlv.valuetype/fr/umlv/valuetype/perf/ReifiedListBenchMark.java#L118
>
> the instructions about how to build are here:
> https://github.com/forax/valuetype-lworld
>
> Rémi
>
> ----- Mail original -----
>> De: "Tobias Hartmann" <tobias.hartmann at oracle.com>
>> À: "Remi Forax" <forax at univ-mlv.fr>, "valhalla-dev" <valhalla-dev at openjdk.java.net>
>> Envoyé: Vendredi 13 Juillet 2018 14:43:10
>> Objet: Re: boxing + unboxing a VT is not a no-op ?
>
>> Hi Remi,
>>
>> thanks for reporting. Could you please provide the full source code so we can
>> have a closer look?
>>
>> Best regards,
>> Tobias
>>
>> On 12.07.2018 20:43, Remi Forax wrote:
>>> Hi guys,
>>> it seems that operations likes VT -> Object -> VT are not optimized has being a
>>> no-op.
>>>
>>> with IntBox being a value type that wrap an int,
>>> this code is slow (not very slow, i.e not interpreter slow)
>>>
>>> public int valuelist_intbox_innervalue_inlined_reduce() {
>>> __ByValue class Adder implements BiFunction<IntBox, IntBox, IntBox> {
>>> private final boolean nonEmpty;
>>>
>>> Adder() {
>>> nonEmpty = false;
>>> throw new AssertionError();
>>> }
>>>
>>> public IntBox apply(IntBox acc, IntBox element) {
>>> return acc.add(element);
>>> }
>>> }
>>> BiFunction<IntBox, IntBox, IntBox> mapper = __MakeDefault Adder();
>>> var sum = IntBox.zero();
>>> int size = valueList.size();
>>> for(int i = 0; i < size; i++) {
>>> sum = mapper.apply(sum, valueList.get(i));
>>> }
>>> return sum.intValue();
>>> }
>>>
>>> while this code is fast (more than 10 times faster)
>>> public int valuelist_intbox_inlined_reduce() {
>>> var sum = IntBox.zero();
>>> int size = valueList.size();
>>> for(int i = 0; i < size; i++) {
>>> sum = sum.add(valueList.get(i));
>>> }
>>> return sum.intValue();
>>> }
>>>
>>> the difference is that instead of calling add on an IntBox to do the addition,
>>> i used an anonymous value class which implement a functional interface which
>>> used Objects.
>>> (valueList is just an array of IntBox wrapped in a value type).
>>>
>>> regards,
>>> Rémi
>>>
More information about the valhalla-dev
mailing list