Unsafe: efficiently comparing two byte arrays
Paul Sandoz
paul.sandoz at oracle.com
Thu Feb 27 17:23:28 UTC 2014
On Feb 27, 2014, at 4:12 PM, Andrew Haley <aph at redhat.com> wrote:
> On 02/27/2014 03:05 PM, Paul Sandoz wrote:
>>
>> On Feb 27, 2014, at 3:52 PM, Andrew Haley <aph at redhat.com> wrote:
>>
>>> Hi,
>>>
>>> On 02/26/2014 03:42 PM, Paul Sandoz wrote:
>>>
>>>> A common reason why Unsafe is used is to more efficiently compare two unsigned byte arrays, viewing those byte arrays as long arrays.
>>>
>>> Why not simply provide ByteBuffer.forArray(byte[]) ? Then we'd have all the ByteBuffer intrinsics for put() and get() operations.
>>
>> Good point, even if it does require the creation of two ByteBuffer instances.
>>
>> An implementation of Arrays.compare could do that if things were suitably intrinsified, which i am not sure is the case as of today.
>>
>> I will do some measurements and report back.
>
> Unless something has been done in HotSpot pretty recently, the
> ByteBuffer intrinsics are not as performat as they might be, so the
> results might be a little underwhelming.
>
Yes.
For this benchmark:
http://cr.openjdk.java.net/~psandoz/unsafe/ByteArrayCompareTest.java
Here are results for comparing two byte arrays of size N containing the same content, on my mac book:
http://cr.openjdk.java.net/~psandoz/unsafe/byte-array-compare-results.txt
The unsafe test is about ~3/4 x faster than the safe test. And the buffer test is slower than the safe test.
I also included a variant of the unsafe test that uses Long.reverseBytes; the results are similar to the unsafe test. I believe reverseBytes is intrinsified as is numberOfTrailingZeros (i tried to disable it with -XX:DisableIntrinsic=_reverseBytes_l but it did not make any great different to the results, which makes me think i configured the option incorrectly).
Paul.
More information about the core-libs-dev
mailing list