It's not safe until it's in the coffer

forax at univ-mlv.fr forax at univ-mlv.fr
Wed May 8 23:28:41 UTC 2019


----- Mail original -----
> De: "John Rose" <john.r.rose at oracle.com>
> À: "Remi Forax" <forax at univ-mlv.fr>
> Cc: "valhalla-spec-experts" <valhalla-spec-experts at openjdk.java.net>
> Envoyé: Jeudi 9 Mai 2019 00:50:10
> Objet: Re: It's not safe until it's in the coffer

> On May 8, 2019, at 3:12 PM, Remi Forax <forax at univ-mlv.fr> wrote:
>> 
>> I propose to use Coffer<Complex> instead of Complex? (with Complex an inline
>> class).
> 
> So you are giving a name, "Coffer", to the Old Contract.
> 
> The javadoc for the named type-constructor could describe
> this contract fully:
> 
>  - array performance profile associated with indirections not inlines
>  - non-tearing indirection-based updates
>  - null in the value set, if the inline type is already null natively
>  - L-descriptors in the JVM (for those who peek)
>  - circularities OK (a Foo can have a field of type Coffer<Foo>)
> 
> Maybe Indirect<VT> is the right name, then?

it's better than Coffer.

> 
> The effect of doing this would be to make the indirect version
> of a type VT to look superficially more like a box, at a time
> when we are trying to downplay boxes.  But it's only superficial.

yes

> 
> The Coffer/Indirect generic is a one-off type constructor,
> like ? itself.  Put another way, matchfix C<.> is just a bulkier
> syntax for postfix-? As such it would have to be documented
> in its essence in the JLS, as well as in its javadoc.
> 
> One consequence of Coffer/Indirect is that it puts a larger
> distance between the two types than VT -vs- VT? does.
> In that, it's sort of like Integer-vs-int.  But unlike boxes,
> natural VT operations are not lifted to Coffer<VT>.
> The difference between VT and VT? is small enough
> that I (for one) would expect operations on VT to be
> lifted to VT?.  We would also expect a type system
> relation between VT and VT?.
> 
> A consequence of bulkier notation is that it's clear that
> VT <: C<VT> is false.  Another is that programmers
> will think twice before saying C<VT> where VT? could be
> an attractive nuisance (like the register keyword).

yes

> 
> So, there are some things to like about this bulky syntax.
> There are lots to dislike:
> 
>  - it's bulky (bug or feature?)
>  - the nullability is less obvious (but maybe that's not a problem)
>  - it's a one-off that has to be defined in JLS and javadoc both
>  - it will remind us of wrappers, sometimes

for the nullability, given that Indirect is not an inline class but an indirect class, i don't think this is an issue.

> 
> — John
> 
> P.S. BTW, would Coffer<?> erase to Object?

It can be but i was not able to find that useful given that V is already a subtype of Object and erasing instanceof Indirect<?> to instanceof Object is surprising. 

> 
> P.P.S. Must… not… mention… covfefe… argh!!!

i hope my proposal will not gone covfefe :)

Rémi


More information about the valhalla-spec-experts mailing list