<!DOCTYPE html><html><head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
Hi John,<br>
<br>
This is covered under discussions of ==, specified in the VM spec as
implemented by the "acmp" bytecode<br>
and described as "same"ness or "substitutability" on the
valhalla-spec-experts archive.<br>
<br>
The discussion of substitutability for float and double along with
more general principles were discussed in February 2024.<br>
See the archives for details:
<a class="moz-txt-link-freetext" href="https://mail.openjdk.org/pipermail/valhalla-spec-experts/2024-February/subject.html">https://mail.openjdk.org/pipermail/valhalla-spec-experts/2024-February/subject.html</a><br>
<br>
Regards, Roger<br>
<br>
<div class="moz-cite-prefix">On 4/7/24 10:30 PM, John Bossons wrote:<br>
</div>
<blockquote type="cite" cite="mid:CACvEv_zm=B8X4DJ=y4LFSaRo6HJezV+WKFw0q-GWcyb_LZJyew@mail.gmail.com">
<div dir="ltr">I'm not sure that this is the right place to raise
this, but don't know where else to do so.
<div><br>
</div>
<div>For identity types, == is simply a test of reference
equality and so is a useful first test in an overriding
type-specific equals method. </div>
<div><br>
</div>
<div>For value types, the relationship is more subtle, since ==
is a test of value equality, not reference equality. I suggest
it be implemented as an operator causing Object::equals to be
invoked, so that if Object::equals is overloaded (e.g. to
first test equality of hash codes or otherwise modify the
default equals test), the overloaded method is automatically
invoked when == is used.</div>
<div><br>
</div>
<div>This would mean that Object::equals implements the ==
operator, rather than the reverse, so that a specification
that a == b always means a.equals(b), whether implemented by
the default test or by an overriding type-specific method
(that e.g. tests for equality of identity object field
values). I believe this would make value types (especially
value trees) easier to use.</div>
<div><br>
</div>
<div>John<br clear="all">
<div><br>
</div>
<span class="gmail_signature_prefix">-- </span><br>
<div dir="ltr" class="gmail_signature" data-smartmail="gmail_signature">
<div dir="ltr">Phone: (416) 450-3584 (cell)</div>
</div>
</div>
</div>
</blockquote>
<br>
</body>
</html>