Dynamic array comparison optimization: check for equal pointers?
Jonathan M Davis
newsgroup.d at jmdavisprog.com
Tue Jun 2 22:48:13 UTC 2020
On Tuesday, June 2, 2020 3:18:40 PM MDT Steven Schveighoffer via Digitalmars-d
wrote:
> On 6/2/20 3:38 PM, Johan wrote:
> > Hi all,
> >
> > I thought that we optimized dynamic array comparison with a check to
> >
> > see if the pointers are equal, but I don't see it in our array
> > comparison implementation in druntime. Quick checking of glibc memcmp
> > also showed that there is no short circuit for when the pointers of the
> > slices are equal.
> >
> > I was expecting something like:
> > ```
> >
> > if ( sizes are not equal )
> > return false;
> > if ( pointers are equal )
> > return true;
> > return memcmp;
> >
> > ```
> >
> > I am surprised that memcmp itself does not implement the pointers are
> > equal check. Is there a big impact of adding the shortcircuit check to
> > prevent scanning memory?
>
> I thought I remembered this being true, but maybe it was for class
> instances? Looking back in history, it seems prior to 2017, it was done
> by the compiler generating the code instead of a template, but seems
> like it did not include the pointer check.
The free function opEquals for classes does check the references first and
has for years (as well doing checks like whether either reference is null).
I've never looked at what the array implementation does though.
- Jonathna M Davis
More information about the Digitalmars-d
mailing list