Project Valhalla – Value Types slides from ScalaDays Amsterdam 2015
Simon Ochsenreither
simon at ochsenreither.de
Fri Jun 12 21:07:19 UTC 2015
Hi Brian, hi Vitaly,
thanks for your comments!
> #11: object headers are typically 2 words; a klass pointer and a word for various identity support (GC mark bits, locking, etc.) Which makes the density story with small objects even worse.
Yes, absolutely! I changed the original from "4 byte" to ">= 4 byte"
only because I was concerned that it would provoke some non-useful
response saying "but obscure JVM vendor implementation X version 23.42
does X in only 4 bytes!!!".
So I decided that "at least 4 bytes" would be better ... but I would be
happy to revise it again if you could provide more information. (E. g.
"_everyone_ implements it this way...")
(Btw, doesn't the klass pointer participate in compressed oops?)
> In general, values give us both DENSITY (memory efficiency) and FLATNESS (cache efficiency.)
You are right, I should have mentioned that! (There are a few things I
mentioned that weren't on the slides, but I forgot a lot to mention, too!)
For instance, I papered over the whole topic of boxing! :-/
> #36: in addition to the __ByValue obviously being a syntax placeholder,
Yes, I made that clear in the talk. Although I should have added that to
the slides too.
> the restrictions outlined e.g. in #38 (must say final) will also go away —
> we’re just not focusing at all on syntax for the time being.
Great, thanks for the info!
> #39: equality on value types will work as it does on primitives (as you suggest on #88)
Thanks!
> #121: good summary
:-)
> 2) value types cannot hold a ref field that's null? I think I saw that
on one of the slides. If so, why?
Maybe that was worded misleadingly. What I meant was that the value type
itself is non-nullable. It can of course have ref fields that can be
null. (I thought the example made it clear ...)
Thanks to both of you for the review.
I think the didn't go too well, because I was working on my slides until
the last minute (projector/filming equipment required 16:9 which meant I
had 300 pixels less height than I assumed). Then I didn't get the
mirroring working on my notebook, so I only had the slides in my back,
the audience in front, and couldn't move to a better place because I
needed to click through the slides on my notebook. :-/
I guess my English grammar was falling apart, too, due to the lack of sleep.
Bye,
Simon
More information about the valhalla-dev
mailing list