The implementations of equals, compare and mismatch can be reimplemented using underlying mismatch methods that in turn defer to a single method, vectorizedMismatch, that accesses the memory contents of arrays using Unsafe.getLongUnaligned.
The vectorizedMismatch implemetnation can be optimized efficiently by C2 to obtain an approximate 8x speed up when performing a mismatch on byte[] arrays (of a suitable size to overcome fixed costs).
The contract of vectorizedMismatch is simple enough that it can be made an intrinsic (see
- blocks
- 
                    JDK-8044082 Efficient array comparison intrinsics -           
- Closed
 
-         
- is blocked by
- 
                    JDK-8033148 Lexicographic comparators and mismatchers for arrays -           
- Closed
 
-         
- relates to
- 
                    JDK-8172156 (array) Tune thresholds for vectorized mismatch in Arrays.equals() -           
- Open
 
-         
- 
                    JDK-8193806 AARCH64: create intrinsic for vectorized mismatch -           
- Closed
 
-         
- 
                    JDK-6655180 (array) Reduce JNI overhead for Arrays.equals() with float/double arrays -           
- Closed
 
-         
- 
                    JDK-8074124 Most Unsafe.get*() access shapes are losing vs. the plain Java accesses -           
- Open
 
-         
- 
                    JDK-8143355 Update for addition of vectorizedMismatch intrinsic for x86 -           
- Resolved
 
-