1 /*
   2  * Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.  Oracle designates this
   8  * particular file as subject to the "Classpath" exception as provided
   9  * by Oracle in the LICENSE file that accompanied this code.
  10  *
  11  * This code is distributed in the hope that it will be useful, but WITHOUT
  12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  14  * version 2 for more details (a copy is included in the LICENSE file that
  15  * accompanied this code).
  16  *
  17  * You should have received a copy of the GNU General Public License version
  18  * 2 along with this work; if not, write to the Free Software Foundation,
  19  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  20  *
  21  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  22  * or visit www.oracle.com if you need additional information or have any
  23  * questions.
  24  */
  25 
  26 package java.util;
  27 
  28 import jdk.internal.util.ArraysSupport;
  29 import jdk.internal.value.ValueClass;
  30 import jdk.internal.vm.annotation.IntrinsicCandidate;
  31 
  32 import java.io.Serializable;
  33 import java.lang.reflect.Array;
  34 import java.util.concurrent.ForkJoinPool;
  35 import java.util.function.BinaryOperator;
  36 import java.util.function.Consumer;
  37 import java.util.function.DoubleBinaryOperator;
  38 import java.util.function.IntBinaryOperator;
  39 import java.util.function.IntFunction;
  40 import java.util.function.IntToDoubleFunction;
  41 import java.util.function.IntToLongFunction;
  42 import java.util.function.IntUnaryOperator;
  43 import java.util.function.LongBinaryOperator;
  44 import java.util.function.UnaryOperator;
  45 import java.util.stream.DoubleStream;
  46 import java.util.stream.IntStream;
  47 import java.util.stream.LongStream;
  48 import java.util.stream.Stream;
  49 import java.util.stream.StreamSupport;
  50 
  51 /**
  52  * This class contains various methods for manipulating arrays (such as
  53  * sorting and searching). This class also contains a static factory
  54  * that allows arrays to be viewed as lists.
  55  *
  56  * <p>The methods in this class all throw a {@code NullPointerException},
  57  * if the specified array reference is null, except where noted.
  58  *
  59  * <p>The documentation for the methods contained in this class includes
  60  * brief descriptions of the <i>implementations</i>. Such descriptions should
  61  * be regarded as <i>implementation notes</i>, rather than parts of the
  62  * <i>specification</i>. Implementors should feel free to substitute other
  63  * algorithms, so long as the specification itself is adhered to. (For
  64  * example, the algorithm used by {@code sort(Object[])} does not have to be
  65  * a MergeSort, but it does have to be <i>stable</i>.)
  66  *
  67  * <p>This class is a member of the
  68  * <a href="{@docRoot}/java.base/java/util/package-summary.html#CollectionsFramework">
  69  * Java Collections Framework</a>.
  70  *
  71  * @author Josh Bloch
  72  * @author Neal Gafter
  73  * @author John Rose
  74  * @since  1.2
  75  */
  76 public final class Arrays {
  77 
  78     // Suppresses default constructor, ensuring non-instantiability.
  79     private Arrays() {}
  80 
  81     /*
  82      * Sorting methods. Note that all public "sort" methods take the
  83      * same form: performing argument checks if necessary, and then
  84      * expanding arguments into those required for the internal
  85      * implementation methods residing in other package-private
  86      * classes (except for legacyMergeSort, included in this class).
  87      */
  88 
  89     /**
  90      * Sorts the specified array into ascending numerical order.
  91      *
  92      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
  93      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
  94      * offers O(n log(n)) performance on all data sets, and is typically
  95      * faster than traditional (one-pivot) Quicksort implementations.
  96      *
  97      * @param a the array to be sorted
  98      */
  99     public static void sort(int[] a) {
 100         DualPivotQuicksort.sort(a, 0, 0, a.length);
 101     }
 102 
 103     /**
 104      * Sorts the specified range of the array into ascending order. The range
 105      * to be sorted extends from the index {@code fromIndex}, inclusive, to
 106      * the index {@code toIndex}, exclusive. If {@code fromIndex == toIndex},
 107      * the range to be sorted is empty.
 108      *
 109      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 110      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 111      * offers O(n log(n)) performance on all data sets, and is typically
 112      * faster than traditional (one-pivot) Quicksort implementations.
 113      *
 114      * @param a the array to be sorted
 115      * @param fromIndex the index of the first element, inclusive, to be sorted
 116      * @param toIndex the index of the last element, exclusive, to be sorted
 117      *
 118      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 119      * @throws ArrayIndexOutOfBoundsException
 120      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 121      */
 122     public static void sort(int[] a, int fromIndex, int toIndex) {
 123         rangeCheck(a.length, fromIndex, toIndex);
 124         DualPivotQuicksort.sort(a, 0, fromIndex, toIndex);
 125     }
 126 
 127     /**
 128      * Sorts the specified array into ascending numerical order.
 129      *
 130      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 131      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 132      * offers O(n log(n)) performance on all data sets, and is typically
 133      * faster than traditional (one-pivot) Quicksort implementations.
 134      *
 135      * @param a the array to be sorted
 136      */
 137     public static void sort(long[] a) {
 138         DualPivotQuicksort.sort(a, 0, 0, a.length);
 139     }
 140 
 141     /**
 142      * Sorts the specified range of the array into ascending order. The range
 143      * to be sorted extends from the index {@code fromIndex}, inclusive, to
 144      * the index {@code toIndex}, exclusive. If {@code fromIndex == toIndex},
 145      * the range to be sorted is empty.
 146      *
 147      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 148      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 149      * offers O(n log(n)) performance on all data sets, and is typically
 150      * faster than traditional (one-pivot) Quicksort implementations.
 151      *
 152      * @param a the array to be sorted
 153      * @param fromIndex the index of the first element, inclusive, to be sorted
 154      * @param toIndex the index of the last element, exclusive, to be sorted
 155      *
 156      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 157      * @throws ArrayIndexOutOfBoundsException
 158      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 159      */
 160     public static void sort(long[] a, int fromIndex, int toIndex) {
 161         rangeCheck(a.length, fromIndex, toIndex);
 162         DualPivotQuicksort.sort(a, 0, fromIndex, toIndex);
 163     }
 164 
 165     /**
 166      * Sorts the specified array into ascending numerical order.
 167      *
 168      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 169      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 170      * offers O(n log(n)) performance on all data sets, and is typically
 171      * faster than traditional (one-pivot) Quicksort implementations.
 172      *
 173      * @param a the array to be sorted
 174      */
 175     public static void sort(short[] a) {
 176         DualPivotQuicksort.sort(a, 0, a.length);
 177     }
 178 
 179     /**
 180      * Sorts the specified range of the array into ascending order. The range
 181      * to be sorted extends from the index {@code fromIndex}, inclusive, to
 182      * the index {@code toIndex}, exclusive. If {@code fromIndex == toIndex},
 183      * the range to be sorted is empty.
 184      *
 185      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 186      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 187      * offers O(n log(n)) performance on all data sets, and is typically
 188      * faster than traditional (one-pivot) Quicksort implementations.
 189      *
 190      * @param a the array to be sorted
 191      * @param fromIndex the index of the first element, inclusive, to be sorted
 192      * @param toIndex the index of the last element, exclusive, to be sorted
 193      *
 194      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 195      * @throws ArrayIndexOutOfBoundsException
 196      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 197      */
 198     public static void sort(short[] a, int fromIndex, int toIndex) {
 199         rangeCheck(a.length, fromIndex, toIndex);
 200         DualPivotQuicksort.sort(a, fromIndex, toIndex);
 201     }
 202 
 203     /**
 204      * Sorts the specified array into ascending numerical order.
 205      *
 206      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 207      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 208      * offers O(n log(n)) performance on all data sets, and is typically
 209      * faster than traditional (one-pivot) Quicksort implementations.
 210      *
 211      * @param a the array to be sorted
 212      */
 213     public static void sort(char[] a) {
 214         DualPivotQuicksort.sort(a, 0, a.length);
 215     }
 216 
 217     /**
 218      * Sorts the specified range of the array into ascending order. The range
 219      * to be sorted extends from the index {@code fromIndex}, inclusive, to
 220      * the index {@code toIndex}, exclusive. If {@code fromIndex == toIndex},
 221      * the range to be sorted is empty.
 222      *
 223      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 224      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 225      * offers O(n log(n)) performance on all data sets, and is typically
 226      * faster than traditional (one-pivot) Quicksort implementations.
 227      *
 228      * @param a the array to be sorted
 229      * @param fromIndex the index of the first element, inclusive, to be sorted
 230      * @param toIndex the index of the last element, exclusive, to be sorted
 231      *
 232      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 233      * @throws ArrayIndexOutOfBoundsException
 234      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 235      */
 236     public static void sort(char[] a, int fromIndex, int toIndex) {
 237         rangeCheck(a.length, fromIndex, toIndex);
 238         DualPivotQuicksort.sort(a, fromIndex, toIndex);
 239     }
 240 
 241     /**
 242      * Sorts the specified array into ascending numerical order.
 243      *
 244      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 245      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 246      * offers O(n log(n)) performance on all data sets, and is typically
 247      * faster than traditional (one-pivot) Quicksort implementations.
 248      *
 249      * @param a the array to be sorted
 250      */
 251     public static void sort(byte[] a) {
 252         DualPivotQuicksort.sort(a, 0, a.length);
 253     }
 254 
 255     /**
 256      * Sorts the specified range of the array into ascending order. The range
 257      * to be sorted extends from the index {@code fromIndex}, inclusive, to
 258      * the index {@code toIndex}, exclusive. If {@code fromIndex == toIndex},
 259      * the range to be sorted is empty.
 260      *
 261      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 262      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 263      * offers O(n log(n)) performance on all data sets, and is typically
 264      * faster than traditional (one-pivot) Quicksort implementations.
 265      *
 266      * @param a the array to be sorted
 267      * @param fromIndex the index of the first element, inclusive, to be sorted
 268      * @param toIndex the index of the last element, exclusive, to be sorted
 269      *
 270      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 271      * @throws ArrayIndexOutOfBoundsException
 272      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 273      */
 274     public static void sort(byte[] a, int fromIndex, int toIndex) {
 275         rangeCheck(a.length, fromIndex, toIndex);
 276         DualPivotQuicksort.sort(a, fromIndex, toIndex);
 277     }
 278 
 279     /**
 280      * Sorts the specified array into ascending numerical order.
 281      *
 282      * <p>The {@code <} relation does not provide a total order on all float
 283      * values: {@code -0.0f == 0.0f} is {@code true} and a {@code Float.NaN}
 284      * value compares neither less than, greater than, nor equal to any value,
 285      * even itself. This method uses the total order imposed by the method
 286      * {@link Float#compareTo}: {@code -0.0f} is treated as less than value
 287      * {@code 0.0f} and {@code Float.NaN} is considered greater than any
 288      * other value and all {@code Float.NaN} values are considered equal.
 289      *
 290      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 291      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 292      * offers O(n log(n)) performance on all data sets, and is typically
 293      * faster than traditional (one-pivot) Quicksort implementations.
 294      *
 295      * @param a the array to be sorted
 296      */
 297     public static void sort(float[] a) {
 298         DualPivotQuicksort.sort(a, 0, 0, a.length);
 299     }
 300 
 301     /**
 302      * Sorts the specified range of the array into ascending order. The range
 303      * to be sorted extends from the index {@code fromIndex}, inclusive, to
 304      * the index {@code toIndex}, exclusive. If {@code fromIndex == toIndex},
 305      * the range to be sorted is empty.
 306      *
 307      * <p>The {@code <} relation does not provide a total order on all float
 308      * values: {@code -0.0f == 0.0f} is {@code true} and a {@code Float.NaN}
 309      * value compares neither less than, greater than, nor equal to any value,
 310      * even itself. This method uses the total order imposed by the method
 311      * {@link Float#compareTo}: {@code -0.0f} is treated as less than value
 312      * {@code 0.0f} and {@code Float.NaN} is considered greater than any
 313      * other value and all {@code Float.NaN} values are considered equal.
 314      *
 315      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 316      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 317      * offers O(n log(n)) performance on all data sets, and is typically
 318      * faster than traditional (one-pivot) Quicksort implementations.
 319      *
 320      * @param a the array to be sorted
 321      * @param fromIndex the index of the first element, inclusive, to be sorted
 322      * @param toIndex the index of the last element, exclusive, to be sorted
 323      *
 324      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 325      * @throws ArrayIndexOutOfBoundsException
 326      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 327      */
 328     public static void sort(float[] a, int fromIndex, int toIndex) {
 329         rangeCheck(a.length, fromIndex, toIndex);
 330         DualPivotQuicksort.sort(a, 0, fromIndex, toIndex);
 331     }
 332 
 333     /**
 334      * Sorts the specified array into ascending numerical order.
 335      *
 336      * <p>The {@code <} relation does not provide a total order on all double
 337      * values: {@code -0.0d == 0.0d} is {@code true} and a {@code Double.NaN}
 338      * value compares neither less than, greater than, nor equal to any value,
 339      * even itself. This method uses the total order imposed by the method
 340      * {@link Double#compareTo}: {@code -0.0d} is treated as less than value
 341      * {@code 0.0d} and {@code Double.NaN} is considered greater than any
 342      * other value and all {@code Double.NaN} values are considered equal.
 343      *
 344      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 345      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 346      * offers O(n log(n)) performance on all data sets, and is typically
 347      * faster than traditional (one-pivot) Quicksort implementations.
 348      *
 349      * @param a the array to be sorted
 350      */
 351     public static void sort(double[] a) {
 352         DualPivotQuicksort.sort(a, 0, 0, a.length);
 353     }
 354 
 355     /**
 356      * Sorts the specified range of the array into ascending order. The range
 357      * to be sorted extends from the index {@code fromIndex}, inclusive, to
 358      * the index {@code toIndex}, exclusive. If {@code fromIndex == toIndex},
 359      * the range to be sorted is empty.
 360      *
 361      * <p>The {@code <} relation does not provide a total order on all double
 362      * values: {@code -0.0d == 0.0d} is {@code true} and a {@code Double.NaN}
 363      * value compares neither less than, greater than, nor equal to any value,
 364      * even itself. This method uses the total order imposed by the method
 365      * {@link Double#compareTo}: {@code -0.0d} is treated as less than value
 366      * {@code 0.0d} and {@code Double.NaN} is considered greater than any
 367      * other value and all {@code Double.NaN} values are considered equal.
 368      *
 369      * @implNote The sorting algorithm is a Dual-Pivot Quicksort
 370      * by Vladimir Yaroslavskiy, Jon Bentley, and Joshua Bloch. This algorithm
 371      * offers O(n log(n)) performance on all data sets, and is typically
 372      * faster than traditional (one-pivot) Quicksort implementations.
 373      *
 374      * @param a the array to be sorted
 375      * @param fromIndex the index of the first element, inclusive, to be sorted
 376      * @param toIndex the index of the last element, exclusive, to be sorted
 377      *
 378      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 379      * @throws ArrayIndexOutOfBoundsException
 380      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 381      */
 382     public static void sort(double[] a, int fromIndex, int toIndex) {
 383         rangeCheck(a.length, fromIndex, toIndex);
 384         DualPivotQuicksort.sort(a, 0, fromIndex, toIndex);
 385     }
 386 
 387     /**
 388      * Sorts the specified array into ascending numerical order.
 389      *
 390      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 391      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 392      * offers O(n log(n)) performance on all data sets, and is typically
 393      * faster than traditional (one-pivot) Quicksort implementations.
 394      *
 395      * @param a the array to be sorted
 396      *
 397      * @since 1.8
 398      */
 399     public static void parallelSort(byte[] a) {
 400         DualPivotQuicksort.sort(a, 0, a.length);
 401     }
 402 
 403     /**
 404      * Sorts the specified range of the array into ascending numerical order.
 405      * The range to be sorted extends from the index {@code fromIndex},
 406      * inclusive, to the index {@code toIndex}, exclusive. If
 407      * {@code fromIndex == toIndex}, the range to be sorted is empty.
 408      *
 409      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 410      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 411      * offers O(n log(n)) performance on all data sets, and is typically
 412      * faster than traditional (one-pivot) Quicksort implementations.
 413      *
 414      * @param a the array to be sorted
 415      * @param fromIndex the index of the first element, inclusive, to be sorted
 416      * @param toIndex the index of the last element, exclusive, to be sorted
 417      *
 418      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 419      * @throws ArrayIndexOutOfBoundsException
 420      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 421      *
 422      * @since 1.8
 423      */
 424     public static void parallelSort(byte[] a, int fromIndex, int toIndex) {
 425         rangeCheck(a.length, fromIndex, toIndex);
 426         DualPivotQuicksort.sort(a, fromIndex, toIndex);
 427     }
 428 
 429     /**
 430      * Sorts the specified array into ascending numerical order.
 431      *
 432      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 433      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 434      * offers O(n log(n)) performance on all data sets, and is typically
 435      * faster than traditional (one-pivot) Quicksort implementations.
 436      *
 437      * @param a the array to be sorted
 438      *
 439      * @since 1.8
 440      */
 441     public static void parallelSort(char[] a) {
 442         DualPivotQuicksort.sort(a, 0, a.length);
 443     }
 444 
 445     /**
 446      * Sorts the specified range of the array into ascending numerical order.
 447      * The range to be sorted extends from the index {@code fromIndex},
 448      * inclusive, to the index {@code toIndex}, exclusive. If
 449      * {@code fromIndex == toIndex}, the range to be sorted is empty.
 450      *
 451      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 452      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 453      * offers O(n log(n)) performance on all data sets, and is typically
 454      * faster than traditional (one-pivot) Quicksort implementations.
 455      *
 456      * @param a the array to be sorted
 457      * @param fromIndex the index of the first element, inclusive, to be sorted
 458      * @param toIndex the index of the last element, exclusive, to be sorted
 459      *
 460      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 461      * @throws ArrayIndexOutOfBoundsException
 462      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 463      *
 464      * @since 1.8
 465      */
 466     public static void parallelSort(char[] a, int fromIndex, int toIndex) {
 467         rangeCheck(a.length, fromIndex, toIndex);
 468         DualPivotQuicksort.sort(a, fromIndex, toIndex);
 469     }
 470 
 471     /**
 472      * Sorts the specified array into ascending numerical order.
 473      *
 474      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 475      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 476      * offers O(n log(n)) performance on all data sets, and is typically
 477      * faster than traditional (one-pivot) Quicksort implementations.
 478      *
 479      * @param a the array to be sorted
 480      *
 481      * @since 1.8
 482      */
 483     public static void parallelSort(short[] a) {
 484         DualPivotQuicksort.sort(a, 0, a.length);
 485     }
 486 
 487     /**
 488      * Sorts the specified range of the array into ascending numerical order.
 489      * The range to be sorted extends from the index {@code fromIndex},
 490      * inclusive, to the index {@code toIndex}, exclusive. If
 491      * {@code fromIndex == toIndex}, the range to be sorted is empty.
 492      *
 493      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 494      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 495      * offers O(n log(n)) performance on all data sets, and is typically
 496      * faster than traditional (one-pivot) Quicksort implementations.
 497      *
 498      * @param a the array to be sorted
 499      * @param fromIndex the index of the first element, inclusive, to be sorted
 500      * @param toIndex the index of the last element, exclusive, to be sorted
 501      *
 502      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 503      * @throws ArrayIndexOutOfBoundsException
 504      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 505      *
 506      * @since 1.8
 507      */
 508     public static void parallelSort(short[] a, int fromIndex, int toIndex) {
 509         rangeCheck(a.length, fromIndex, toIndex);
 510         DualPivotQuicksort.sort(a, fromIndex, toIndex);
 511     }
 512 
 513     /**
 514      * Sorts the specified array into ascending numerical order.
 515      *
 516      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 517      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 518      * offers O(n log(n)) performance on all data sets, and is typically
 519      * faster than traditional (one-pivot) Quicksort implementations.
 520      *
 521      * @param a the array to be sorted
 522      *
 523      * @since 1.8
 524      */
 525     public static void parallelSort(int[] a) {
 526         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), 0, a.length);
 527     }
 528 
 529     /**
 530      * Sorts the specified range of the array into ascending numerical order.
 531      * The range to be sorted extends from the index {@code fromIndex},
 532      * inclusive, to the index {@code toIndex}, exclusive. If
 533      * {@code fromIndex == toIndex}, the range to be sorted is empty.
 534      *
 535      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 536      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 537      * offers O(n log(n)) performance on all data sets, and is typically
 538      * faster than traditional (one-pivot) Quicksort implementations.
 539      *
 540      * @param a the array to be sorted
 541      * @param fromIndex the index of the first element, inclusive, to be sorted
 542      * @param toIndex the index of the last element, exclusive, to be sorted
 543      *
 544      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 545      * @throws ArrayIndexOutOfBoundsException
 546      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 547      *
 548      * @since 1.8
 549      */
 550     public static void parallelSort(int[] a, int fromIndex, int toIndex) {
 551         rangeCheck(a.length, fromIndex, toIndex);
 552         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), fromIndex, toIndex);
 553     }
 554 
 555     /**
 556      * Sorts the specified array into ascending numerical order.
 557      *
 558      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 559      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 560      * offers O(n log(n)) performance on all data sets, and is typically
 561      * faster than traditional (one-pivot) Quicksort implementations.
 562      *
 563      * @param a the array to be sorted
 564      *
 565      * @since 1.8
 566      */
 567     public static void parallelSort(long[] a) {
 568         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), 0, a.length);
 569     }
 570 
 571     /**
 572      * Sorts the specified range of the array into ascending numerical order.
 573      * The range to be sorted extends from the index {@code fromIndex},
 574      * inclusive, to the index {@code toIndex}, exclusive. If
 575      * {@code fromIndex == toIndex}, the range to be sorted is empty.
 576      *
 577      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 578      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 579      * offers O(n log(n)) performance on all data sets, and is typically
 580      * faster than traditional (one-pivot) Quicksort implementations.
 581      *
 582      * @param a the array to be sorted
 583      * @param fromIndex the index of the first element, inclusive, to be sorted
 584      * @param toIndex the index of the last element, exclusive, to be sorted
 585      *
 586      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 587      * @throws ArrayIndexOutOfBoundsException
 588      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 589      *
 590      * @since 1.8
 591      */
 592     public static void parallelSort(long[] a, int fromIndex, int toIndex) {
 593         rangeCheck(a.length, fromIndex, toIndex);
 594         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), fromIndex, toIndex);
 595     }
 596 
 597     /**
 598      * Sorts the specified array into ascending numerical order.
 599      *
 600      * <p>The {@code <} relation does not provide a total order on all float
 601      * values: {@code -0.0f == 0.0f} is {@code true} and a {@code Float.NaN}
 602      * value compares neither less than, greater than, nor equal to any value,
 603      * even itself. This method uses the total order imposed by the method
 604      * {@link Float#compareTo}: {@code -0.0f} is treated as less than value
 605      * {@code 0.0f} and {@code Float.NaN} is considered greater than any
 606      * other value and all {@code Float.NaN} values are considered equal.
 607      *
 608      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 609      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 610      * offers O(n log(n)) performance on all data sets, and is typically
 611      * faster than traditional (one-pivot) Quicksort implementations.
 612      *
 613      * @param a the array to be sorted
 614      *
 615      * @since 1.8
 616      */
 617     public static void parallelSort(float[] a) {
 618         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), 0, a.length);
 619     }
 620 
 621     /**
 622      * Sorts the specified range of the array into ascending numerical order.
 623      * The range to be sorted extends from the index {@code fromIndex},
 624      * inclusive, to the index {@code toIndex}, exclusive. If
 625      * {@code fromIndex == toIndex}, the range to be sorted is empty.
 626      *
 627      * <p>The {@code <} relation does not provide a total order on all float
 628      * values: {@code -0.0f == 0.0f} is {@code true} and a {@code Float.NaN}
 629      * value compares neither less than, greater than, nor equal to any value,
 630      * even itself. This method uses the total order imposed by the method
 631      * {@link Float#compareTo}: {@code -0.0f} is treated as less than value
 632      * {@code 0.0f} and {@code Float.NaN} is considered greater than any
 633      * other value and all {@code Float.NaN} values are considered equal.
 634      *
 635      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 636      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 637      * offers O(n log(n)) performance on all data sets, and is typically
 638      * faster than traditional (one-pivot) Quicksort implementations.
 639      *
 640      * @param a the array to be sorted
 641      * @param fromIndex the index of the first element, inclusive, to be sorted
 642      * @param toIndex the index of the last element, exclusive, to be sorted
 643      *
 644      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 645      * @throws ArrayIndexOutOfBoundsException
 646      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 647      *
 648      * @since 1.8
 649      */
 650     public static void parallelSort(float[] a, int fromIndex, int toIndex) {
 651         rangeCheck(a.length, fromIndex, toIndex);
 652         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), fromIndex, toIndex);
 653     }
 654 
 655     /**
 656      * Sorts the specified array into ascending numerical order.
 657      *
 658      * <p>The {@code <} relation does not provide a total order on all double
 659      * values: {@code -0.0d == 0.0d} is {@code true} and a {@code Double.NaN}
 660      * value compares neither less than, greater than, nor equal to any value,
 661      * even itself. This method uses the total order imposed by the method
 662      * {@link Double#compareTo}: {@code -0.0d} is treated as less than value
 663      * {@code 0.0d} and {@code Double.NaN} is considered greater than any
 664      * other value and all {@code Double.NaN} values are considered equal.
 665      *
 666      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 667      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 668      * offers O(n log(n)) performance on all data sets, and is typically
 669      * faster than traditional (one-pivot) Quicksort implementations.
 670      *
 671      * @param a the array to be sorted
 672      *
 673      * @since 1.8
 674      */
 675     public static void parallelSort(double[] a) {
 676         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), 0, a.length);
 677     }
 678 
 679     /**
 680      * Sorts the specified range of the array into ascending numerical order.
 681      * The range to be sorted extends from the index {@code fromIndex},
 682      * inclusive, to the index {@code toIndex}, exclusive. If
 683      * {@code fromIndex == toIndex}, the range to be sorted is empty.
 684      *
 685      * <p>The {@code <} relation does not provide a total order on all double
 686      * values: {@code -0.0d == 0.0d} is {@code true} and a {@code Double.NaN}
 687      * value compares neither less than, greater than, nor equal to any value,
 688      * even itself. This method uses the total order imposed by the method
 689      * {@link Double#compareTo}: {@code -0.0d} is treated as less than value
 690      * {@code 0.0d} and {@code Double.NaN} is considered greater than any
 691      * other value and all {@code Double.NaN} values are considered equal.
 692      *
 693      * @implNote The sorting algorithm is a Dual-Pivot Quicksort by
 694      * Vladimir Yaroslavskiy, Jon Bentley and Josh Bloch. This algorithm
 695      * offers O(n log(n)) performance on all data sets, and is typically
 696      * faster than traditional (one-pivot) Quicksort implementations.
 697      *
 698      * @param a the array to be sorted
 699      * @param fromIndex the index of the first element, inclusive, to be sorted
 700      * @param toIndex the index of the last element, exclusive, to be sorted
 701      *
 702      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
 703      * @throws ArrayIndexOutOfBoundsException
 704      *     if {@code fromIndex < 0} or {@code toIndex > a.length}
 705      *
 706      * @since 1.8
 707      */
 708     public static void parallelSort(double[] a, int fromIndex, int toIndex) {
 709         rangeCheck(a.length, fromIndex, toIndex);
 710         DualPivotQuicksort.sort(a, ForkJoinPool.getCommonPoolParallelism(), fromIndex, toIndex);
 711     }
 712 
 713     /**
 714      * Checks that {@code fromIndex} and {@code toIndex} are in
 715      * the range and throws an exception if they aren't.
 716      */
 717     static void rangeCheck(int arrayLength, int fromIndex, int toIndex) {
 718         if (fromIndex > toIndex) {
 719             throw new IllegalArgumentException(
 720                 "fromIndex(" + fromIndex + ") > toIndex(" + toIndex + ")");
 721         }
 722         if (fromIndex < 0) {
 723             throw new ArrayIndexOutOfBoundsException(fromIndex);
 724         }
 725         if (toIndex > arrayLength) {
 726             throw new ArrayIndexOutOfBoundsException(toIndex);
 727         }
 728     }
 729 
 730     /**
 731      * A comparator that implements the natural ordering of a group of
 732      * mutually comparable elements. May be used when a supplied
 733      * comparator is null. To simplify code-sharing within underlying
 734      * implementations, the compare method only declares type Object
 735      * for its second argument.
 736      *
 737      * Arrays class implementor's note: It is an empirical matter
 738      * whether ComparableTimSort offers any performance benefit over
 739      * TimSort used with this comparator.  If not, you are better off
 740      * deleting or bypassing ComparableTimSort.  There is currently no
 741      * empirical case for separating them for parallel sorting, so all
 742      * public Object parallelSort methods use the same comparator
 743      * based implementation.
 744      */
 745     static final class NaturalOrder implements Comparator<Object> {
 746         @SuppressWarnings("unchecked")
 747         public int compare(Object first, Object second) {
 748             return ((Comparable<Object>)first).compareTo(second);
 749         }
 750         static final NaturalOrder INSTANCE = new NaturalOrder();
 751     }
 752 
 753     /**
 754      * The minimum array length below which a parallel sorting
 755      * algorithm will not further partition the sorting task. Using
 756      * smaller sizes typically results in memory contention across
 757      * tasks that makes parallel speedups unlikely.
 758      */
 759     private static final int MIN_ARRAY_SORT_GRAN = 1 << 13;
 760 
 761     /**
 762      * Sorts the specified array of objects into ascending order, according
 763      * to the {@linkplain Comparable natural ordering} of its elements.
 764      * All elements in the array must implement the {@link Comparable}
 765      * interface.  Furthermore, all elements in the array must be
 766      * <i>mutually comparable</i> (that is, {@code e1.compareTo(e2)} must
 767      * not throw a {@code ClassCastException} for any elements {@code e1}
 768      * and {@code e2} in the array).
 769      *
 770      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
 771      * not be reordered as a result of the sort.
 772      *
 773      * @implNote The sorting algorithm is a parallel sort-merge that breaks the
 774      * array into sub-arrays that are themselves sorted and then merged. When
 775      * the sub-array length reaches a minimum granularity, the sub-array is
 776      * sorted using the appropriate {@link Arrays#sort(Object[]) Arrays.sort}
 777      * method. If the length of the specified array is less than the minimum
 778      * granularity, then it is sorted using the appropriate {@link
 779      * Arrays#sort(Object[]) Arrays.sort} method. The algorithm requires a
 780      * working space no greater than the size of the original array. The
 781      * {@link ForkJoinPool#commonPool() ForkJoin common pool} is used to
 782      * execute any parallel tasks.
 783      *
 784      * @param <T> the class of the objects to be sorted
 785      * @param a the array to be sorted
 786      *
 787      * @throws ClassCastException if the array contains elements that are not
 788      *         <i>mutually comparable</i> (for example, strings and integers)
 789      * @throws IllegalArgumentException (optional) if the natural
 790      *         ordering of the array elements is found to violate the
 791      *         {@link Comparable} contract
 792      *
 793      * @since 1.8
 794      */
 795     @SuppressWarnings("unchecked")
 796     public static <T extends Comparable<? super T>> void parallelSort(T[] a) {
 797         int n = a.length, p, g;
 798         if (n <= MIN_ARRAY_SORT_GRAN ||
 799             (p = ForkJoinPool.getCommonPoolParallelism()) == 1)
 800             TimSort.sort(a, 0, n, NaturalOrder.INSTANCE, null, 0, 0);
 801         else
 802             new ArraysParallelSortHelpers.FJObject.Sorter<>
 803                 (null, a,
 804                  (T[])Array.newInstance(a.getClass().getComponentType(), n),
 805                  0, n, 0, ((g = n / (p << 2)) <= MIN_ARRAY_SORT_GRAN) ?
 806                  MIN_ARRAY_SORT_GRAN : g, NaturalOrder.INSTANCE).invoke();
 807     }
 808 
 809     /**
 810      * Sorts the specified range of the specified array of objects into
 811      * ascending order, according to the
 812      * {@linkplain Comparable natural ordering} of its
 813      * elements.  The range to be sorted extends from index
 814      * {@code fromIndex}, inclusive, to index {@code toIndex}, exclusive.
 815      * (If {@code fromIndex==toIndex}, the range to be sorted is empty.)  All
 816      * elements in this range must implement the {@link Comparable}
 817      * interface.  Furthermore, all elements in this range must be <i>mutually
 818      * comparable</i> (that is, {@code e1.compareTo(e2)} must not throw a
 819      * {@code ClassCastException} for any elements {@code e1} and
 820      * {@code e2} in the array).
 821      *
 822      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
 823      * not be reordered as a result of the sort.
 824      *
 825      * @implNote The sorting algorithm is a parallel sort-merge that breaks the
 826      * array into sub-arrays that are themselves sorted and then merged. When
 827      * the sub-array length reaches a minimum granularity, the sub-array is
 828      * sorted using the appropriate {@link Arrays#sort(Object[]) Arrays.sort}
 829      * method. If the length of the specified array is less than the minimum
 830      * granularity, then it is sorted using the appropriate {@link
 831      * Arrays#sort(Object[]) Arrays.sort} method. The algorithm requires a working
 832      * space no greater than the size of the specified range of the original
 833      * array. The {@link ForkJoinPool#commonPool() ForkJoin common pool} is
 834      * used to execute any parallel tasks.
 835      *
 836      * @param <T> the class of the objects to be sorted
 837      * @param a the array to be sorted
 838      * @param fromIndex the index of the first element (inclusive) to be
 839      *        sorted
 840      * @param toIndex the index of the last element (exclusive) to be sorted
 841      * @throws IllegalArgumentException if {@code fromIndex > toIndex} or
 842      *         (optional) if the natural ordering of the array elements is
 843      *         found to violate the {@link Comparable} contract
 844      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
 845      *         {@code toIndex > a.length}
 846      * @throws ClassCastException if the array contains elements that are
 847      *         not <i>mutually comparable</i> (for example, strings and
 848      *         integers).
 849      *
 850      * @since 1.8
 851      */
 852     @SuppressWarnings("unchecked")
 853     public static <T extends Comparable<? super T>>
 854     void parallelSort(T[] a, int fromIndex, int toIndex) {
 855         rangeCheck(a.length, fromIndex, toIndex);
 856         int n = toIndex - fromIndex, p, g;
 857         if (n <= MIN_ARRAY_SORT_GRAN ||
 858             (p = ForkJoinPool.getCommonPoolParallelism()) == 1)
 859             TimSort.sort(a, fromIndex, toIndex, NaturalOrder.INSTANCE, null, 0, 0);
 860         else
 861             new ArraysParallelSortHelpers.FJObject.Sorter<>
 862                 (null, a,
 863                  (T[])Array.newInstance(a.getClass().getComponentType(), n),
 864                  fromIndex, n, 0, ((g = n / (p << 2)) <= MIN_ARRAY_SORT_GRAN) ?
 865                  MIN_ARRAY_SORT_GRAN : g, NaturalOrder.INSTANCE).invoke();
 866     }
 867 
 868     /**
 869      * Sorts the specified array of objects according to the order induced by
 870      * the specified comparator.  All elements in the array must be
 871      * <i>mutually comparable</i> by the specified comparator (that is,
 872      * {@code c.compare(e1, e2)} must not throw a {@code ClassCastException}
 873      * for any elements {@code e1} and {@code e2} in the array).
 874      *
 875      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
 876      * not be reordered as a result of the sort.
 877      *
 878      * @implNote The sorting algorithm is a parallel sort-merge that breaks the
 879      * array into sub-arrays that are themselves sorted and then merged. When
 880      * the sub-array length reaches a minimum granularity, the sub-array is
 881      * sorted using the appropriate {@link Arrays#sort(Object[]) Arrays.sort}
 882      * method. If the length of the specified array is less than the minimum
 883      * granularity, then it is sorted using the appropriate {@link
 884      * Arrays#sort(Object[]) Arrays.sort} method. The algorithm requires a
 885      * working space no greater than the size of the original array. The
 886      * {@link ForkJoinPool#commonPool() ForkJoin common pool} is used to
 887      * execute any parallel tasks.
 888      *
 889      * @param <T> the class of the objects to be sorted
 890      * @param a the array to be sorted
 891      * @param cmp the comparator to determine the order of the array.  A
 892      *        {@code null} value indicates that the elements'
 893      *        {@linkplain Comparable natural ordering} should be used.
 894      * @throws ClassCastException if the array contains elements that are
 895      *         not <i>mutually comparable</i> using the specified comparator
 896      * @throws IllegalArgumentException (optional) if the comparator is
 897      *         found to violate the {@link java.util.Comparator} contract
 898      *
 899      * @since 1.8
 900      */
 901     @SuppressWarnings("unchecked")
 902     public static <T> void parallelSort(T[] a, Comparator<? super T> cmp) {
 903         if (cmp == null)
 904             cmp = NaturalOrder.INSTANCE;
 905         int n = a.length, p, g;
 906         if (n <= MIN_ARRAY_SORT_GRAN ||
 907             (p = ForkJoinPool.getCommonPoolParallelism()) == 1)
 908             TimSort.sort(a, 0, n, cmp, null, 0, 0);
 909         else
 910             new ArraysParallelSortHelpers.FJObject.Sorter<>
 911                 (null, a,
 912                  (T[])Array.newInstance(a.getClass().getComponentType(), n),
 913                  0, n, 0, ((g = n / (p << 2)) <= MIN_ARRAY_SORT_GRAN) ?
 914                  MIN_ARRAY_SORT_GRAN : g, cmp).invoke();
 915     }
 916 
 917     /**
 918      * Sorts the specified range of the specified array of objects according
 919      * to the order induced by the specified comparator.  The range to be
 920      * sorted extends from index {@code fromIndex}, inclusive, to index
 921      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
 922      * range to be sorted is empty.)  All elements in the range must be
 923      * <i>mutually comparable</i> by the specified comparator (that is,
 924      * {@code c.compare(e1, e2)} must not throw a {@code ClassCastException}
 925      * for any elements {@code e1} and {@code e2} in the range).
 926      *
 927      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
 928      * not be reordered as a result of the sort.
 929      *
 930      * @implNote The sorting algorithm is a parallel sort-merge that breaks the
 931      * array into sub-arrays that are themselves sorted and then merged. When
 932      * the sub-array length reaches a minimum granularity, the sub-array is
 933      * sorted using the appropriate {@link Arrays#sort(Object[]) Arrays.sort}
 934      * method. If the length of the specified array is less than the minimum
 935      * granularity, then it is sorted using the appropriate {@link
 936      * Arrays#sort(Object[]) Arrays.sort} method. The algorithm requires a working
 937      * space no greater than the size of the specified range of the original
 938      * array. The {@link ForkJoinPool#commonPool() ForkJoin common pool} is
 939      * used to execute any parallel tasks.
 940      *
 941      * @param <T> the class of the objects to be sorted
 942      * @param a the array to be sorted
 943      * @param fromIndex the index of the first element (inclusive) to be
 944      *        sorted
 945      * @param toIndex the index of the last element (exclusive) to be sorted
 946      * @param cmp the comparator to determine the order of the array.  A
 947      *        {@code null} value indicates that the elements'
 948      *        {@linkplain Comparable natural ordering} should be used.
 949      * @throws IllegalArgumentException if {@code fromIndex > toIndex} or
 950      *         (optional) if the natural ordering of the array elements is
 951      *         found to violate the {@link Comparable} contract
 952      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
 953      *         {@code toIndex > a.length}
 954      * @throws ClassCastException if the array contains elements that are
 955      *         not <i>mutually comparable</i> (for example, strings and
 956      *         integers).
 957      *
 958      * @since 1.8
 959      */
 960     @SuppressWarnings("unchecked")
 961     public static <T> void parallelSort(T[] a, int fromIndex, int toIndex,
 962                                         Comparator<? super T> cmp) {
 963         rangeCheck(a.length, fromIndex, toIndex);
 964         if (cmp == null)
 965             cmp = NaturalOrder.INSTANCE;
 966         int n = toIndex - fromIndex, p, g;
 967         if (n <= MIN_ARRAY_SORT_GRAN ||
 968             (p = ForkJoinPool.getCommonPoolParallelism()) == 1)
 969             TimSort.sort(a, fromIndex, toIndex, cmp, null, 0, 0);
 970         else
 971             new ArraysParallelSortHelpers.FJObject.Sorter<>
 972                 (null, a,
 973                  (T[])Array.newInstance(a.getClass().getComponentType(), n),
 974                  fromIndex, n, 0, ((g = n / (p << 2)) <= MIN_ARRAY_SORT_GRAN) ?
 975                  MIN_ARRAY_SORT_GRAN : g, cmp).invoke();
 976     }
 977 
 978     /*
 979      * Sorting of complex type arrays.
 980      */
 981 
 982     /**
 983      * Old merge sort implementation can be selected (for
 984      * compatibility with broken comparators) using a system property.
 985      * Cannot be a static boolean in the enclosing class due to
 986      * circular dependencies. To be removed in a future release.
 987      */
 988     static final class LegacyMergeSort {
 989         @SuppressWarnings("removal")
 990         private static final boolean userRequested =
 991             java.security.AccessController.doPrivileged(
 992                 new sun.security.action.GetBooleanAction(
 993                     "java.util.Arrays.useLegacyMergeSort")).booleanValue();
 994     }
 995 
 996     /**
 997      * Sorts the specified array of objects into ascending order, according
 998      * to the {@linkplain Comparable natural ordering} of its elements.
 999      * All elements in the array must implement the {@link Comparable}
1000      * interface.  Furthermore, all elements in the array must be
1001      * <i>mutually comparable</i> (that is, {@code e1.compareTo(e2)} must
1002      * not throw a {@code ClassCastException} for any elements {@code e1}
1003      * and {@code e2} in the array).
1004      *
1005      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
1006      * not be reordered as a result of the sort.
1007      *
1008      * <p>Implementation note: This implementation is a stable, adaptive,
1009      * iterative mergesort that requires far fewer than n lg(n) comparisons
1010      * when the input array is partially sorted, while offering the
1011      * performance of a traditional mergesort when the input array is
1012      * randomly ordered.  If the input array is nearly sorted, the
1013      * implementation requires approximately n comparisons.  Temporary
1014      * storage requirements vary from a small constant for nearly sorted
1015      * input arrays to n/2 object references for randomly ordered input
1016      * arrays.
1017      *
1018      * <p>The implementation takes equal advantage of ascending and
1019      * descending order in its input array, and can take advantage of
1020      * ascending and descending order in different parts of the same
1021      * input array.  It is well-suited to merging two or more sorted arrays:
1022      * simply concatenate the arrays and sort the resulting array.
1023      *
1024      * <p>The implementation was adapted from Tim Peters's list sort for Python
1025      * (<a href="http://svn.python.org/projects/python/trunk/Objects/listsort.txt">
1026      * TimSort</a>).  It uses techniques from Peter McIlroy's "Optimistic
1027      * Sorting and Information Theoretic Complexity", in Proceedings of the
1028      * Fourth Annual ACM-SIAM Symposium on Discrete Algorithms, pp 467-474,
1029      * January 1993.
1030      *
1031      * @param a the array to be sorted
1032      * @throws ClassCastException if the array contains elements that are not
1033      *         <i>mutually comparable</i> (for example, strings and integers)
1034      * @throws IllegalArgumentException (optional) if the natural
1035      *         ordering of the array elements is found to violate the
1036      *         {@link Comparable} contract
1037      */
1038     public static void sort(Object[] a) {
1039         if (LegacyMergeSort.userRequested)
1040             legacyMergeSort(a);
1041         else
1042             ComparableTimSort.sort(a, 0, a.length, null, 0, 0);
1043     }
1044 
1045     /** To be removed in a future release. */
1046     private static void legacyMergeSort(Object[] a) {
1047         Object[] aux = a.clone();
1048         mergeSort(aux, a, 0, a.length, 0);
1049     }
1050 
1051     /**
1052      * Sorts the specified range of the specified array of objects into
1053      * ascending order, according to the
1054      * {@linkplain Comparable natural ordering} of its
1055      * elements.  The range to be sorted extends from index
1056      * {@code fromIndex}, inclusive, to index {@code toIndex}, exclusive.
1057      * (If {@code fromIndex==toIndex}, the range to be sorted is empty.)  All
1058      * elements in this range must implement the {@link Comparable}
1059      * interface.  Furthermore, all elements in this range must be <i>mutually
1060      * comparable</i> (that is, {@code e1.compareTo(e2)} must not throw a
1061      * {@code ClassCastException} for any elements {@code e1} and
1062      * {@code e2} in the array).
1063      *
1064      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
1065      * not be reordered as a result of the sort.
1066      *
1067      * <p>Implementation note: This implementation is a stable, adaptive,
1068      * iterative mergesort that requires far fewer than n lg(n) comparisons
1069      * when the input array is partially sorted, while offering the
1070      * performance of a traditional mergesort when the input array is
1071      * randomly ordered.  If the input array is nearly sorted, the
1072      * implementation requires approximately n comparisons.  Temporary
1073      * storage requirements vary from a small constant for nearly sorted
1074      * input arrays to n/2 object references for randomly ordered input
1075      * arrays.
1076      *
1077      * <p>The implementation takes equal advantage of ascending and
1078      * descending order in its input array, and can take advantage of
1079      * ascending and descending order in different parts of the same
1080      * input array.  It is well-suited to merging two or more sorted arrays:
1081      * simply concatenate the arrays and sort the resulting array.
1082      *
1083      * <p>The implementation was adapted from Tim Peters's list sort for Python
1084      * (<a href="http://svn.python.org/projects/python/trunk/Objects/listsort.txt">
1085      * TimSort</a>).  It uses techniques from Peter McIlroy's "Optimistic
1086      * Sorting and Information Theoretic Complexity", in Proceedings of the
1087      * Fourth Annual ACM-SIAM Symposium on Discrete Algorithms, pp 467-474,
1088      * January 1993.
1089      *
1090      * @param a the array to be sorted
1091      * @param fromIndex the index of the first element (inclusive) to be
1092      *        sorted
1093      * @param toIndex the index of the last element (exclusive) to be sorted
1094      * @throws IllegalArgumentException if {@code fromIndex > toIndex} or
1095      *         (optional) if the natural ordering of the array elements is
1096      *         found to violate the {@link Comparable} contract
1097      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
1098      *         {@code toIndex > a.length}
1099      * @throws ClassCastException if the array contains elements that are
1100      *         not <i>mutually comparable</i> (for example, strings and
1101      *         integers).
1102      */
1103     public static void sort(Object[] a, int fromIndex, int toIndex) {
1104         rangeCheck(a.length, fromIndex, toIndex);
1105         if (LegacyMergeSort.userRequested)
1106             legacyMergeSort(a, fromIndex, toIndex);
1107         else
1108             ComparableTimSort.sort(a, fromIndex, toIndex, null, 0, 0);
1109     }
1110 
1111     /** To be removed in a future release. */
1112     private static void legacyMergeSort(Object[] a,
1113                                         int fromIndex, int toIndex) {
1114         Object[] aux = copyOfRange(a, fromIndex, toIndex);
1115         mergeSort(aux, a, fromIndex, toIndex, -fromIndex);
1116     }
1117 
1118     /**
1119      * Tuning parameter: list size at or below which insertion sort will be
1120      * used in preference to mergesort.
1121      * To be removed in a future release.
1122      */
1123     private static final int INSERTIONSORT_THRESHOLD = 7;
1124 
1125     /**
1126      * Src is the source array that starts at index 0
1127      * Dest is the (possibly larger) array destination with a possible offset
1128      * low is the index in dest to start sorting
1129      * high is the end index in dest to end sorting
1130      * off is the offset to generate corresponding low, high in src
1131      * To be removed in a future release.
1132      */
1133     @SuppressWarnings({"unchecked", "rawtypes"})
1134     private static void mergeSort(Object[] src,
1135                                   Object[] dest,
1136                                   int low,
1137                                   int high,
1138                                   int off) {
1139         int length = high - low;
1140 
1141         // Insertion sort on smallest arrays
1142         if (length < INSERTIONSORT_THRESHOLD) {
1143             for (int i=low; i<high; i++)
1144                 for (int j=i; j>low &&
1145                          ((Comparable) dest[j-1]).compareTo(dest[j])>0; j--)
1146                     swap(dest, j, j-1);
1147             return;
1148         }
1149 
1150         // Recursively sort halves of dest into src
1151         int destLow  = low;
1152         int destHigh = high;
1153         low  += off;
1154         high += off;
1155         int mid = (low + high) >>> 1;
1156         mergeSort(dest, src, low, mid, -off);
1157         mergeSort(dest, src, mid, high, -off);
1158 
1159         // If list is already sorted, just copy from src to dest.  This is an
1160         // optimization that results in faster sorts for nearly ordered lists.
1161         if (((Comparable)src[mid-1]).compareTo(src[mid]) <= 0) {
1162             System.arraycopy(src, low, dest, destLow, length);
1163             return;
1164         }
1165 
1166         // Merge sorted halves (now in src) into dest
1167         for(int i = destLow, p = low, q = mid; i < destHigh; i++) {
1168             if (q >= high || p < mid && ((Comparable)src[p]).compareTo(src[q])<=0)
1169                 dest[i] = src[p++];
1170             else
1171                 dest[i] = src[q++];
1172         }
1173     }
1174 
1175     /**
1176      * Swaps x[a] with x[b].
1177      */
1178     private static void swap(Object[] x, int a, int b) {
1179         Object t = x[a];
1180         x[a] = x[b];
1181         x[b] = t;
1182     }
1183 
1184     /**
1185      * Sorts the specified array of objects according to the order induced by
1186      * the specified comparator.  All elements in the array must be
1187      * <i>mutually comparable</i> by the specified comparator (that is,
1188      * {@code c.compare(e1, e2)} must not throw a {@code ClassCastException}
1189      * for any elements {@code e1} and {@code e2} in the array).
1190      *
1191      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
1192      * not be reordered as a result of the sort.
1193      *
1194      * <p>Implementation note: This implementation is a stable, adaptive,
1195      * iterative mergesort that requires far fewer than n lg(n) comparisons
1196      * when the input array is partially sorted, while offering the
1197      * performance of a traditional mergesort when the input array is
1198      * randomly ordered.  If the input array is nearly sorted, the
1199      * implementation requires approximately n comparisons.  Temporary
1200      * storage requirements vary from a small constant for nearly sorted
1201      * input arrays to n/2 object references for randomly ordered input
1202      * arrays.
1203      *
1204      * <p>The implementation takes equal advantage of ascending and
1205      * descending order in its input array, and can take advantage of
1206      * ascending and descending order in different parts of the same
1207      * input array.  It is well-suited to merging two or more sorted arrays:
1208      * simply concatenate the arrays and sort the resulting array.
1209      *
1210      * <p>The implementation was adapted from Tim Peters's list sort for Python
1211      * (<a href="http://svn.python.org/projects/python/trunk/Objects/listsort.txt">
1212      * TimSort</a>).  It uses techniques from Peter McIlroy's "Optimistic
1213      * Sorting and Information Theoretic Complexity", in Proceedings of the
1214      * Fourth Annual ACM-SIAM Symposium on Discrete Algorithms, pp 467-474,
1215      * January 1993.
1216      *
1217      * @param <T> the class of the objects to be sorted
1218      * @param a the array to be sorted
1219      * @param c the comparator to determine the order of the array.  A
1220      *        {@code null} value indicates that the elements'
1221      *        {@linkplain Comparable natural ordering} should be used.
1222      * @throws ClassCastException if the array contains elements that are
1223      *         not <i>mutually comparable</i> using the specified comparator
1224      * @throws IllegalArgumentException (optional) if the comparator is
1225      *         found to violate the {@link Comparator} contract
1226      */
1227     public static <T> void sort(T[] a, Comparator<? super T> c) {
1228         if (c == null) {
1229             sort(a);
1230         } else {
1231             if (LegacyMergeSort.userRequested)
1232                 legacyMergeSort(a, c);
1233             else
1234                 TimSort.sort(a, 0, a.length, c, null, 0, 0);
1235         }
1236     }
1237 
1238     /** To be removed in a future release. */
1239     private static <T> void legacyMergeSort(T[] a, Comparator<? super T> c) {
1240         T[] aux = a.clone();
1241         if (c==null)
1242             mergeSort(aux, a, 0, a.length, 0);
1243         else
1244             mergeSort(aux, a, 0, a.length, 0, c);
1245     }
1246 
1247     /**
1248      * Sorts the specified range of the specified array of objects according
1249      * to the order induced by the specified comparator.  The range to be
1250      * sorted extends from index {@code fromIndex}, inclusive, to index
1251      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
1252      * range to be sorted is empty.)  All elements in the range must be
1253      * <i>mutually comparable</i> by the specified comparator (that is,
1254      * {@code c.compare(e1, e2)} must not throw a {@code ClassCastException}
1255      * for any elements {@code e1} and {@code e2} in the range).
1256      *
1257      * <p>This sort is guaranteed to be <i>stable</i>:  equal elements will
1258      * not be reordered as a result of the sort.
1259      *
1260      * <p>Implementation note: This implementation is a stable, adaptive,
1261      * iterative mergesort that requires far fewer than n lg(n) comparisons
1262      * when the input array is partially sorted, while offering the
1263      * performance of a traditional mergesort when the input array is
1264      * randomly ordered.  If the input array is nearly sorted, the
1265      * implementation requires approximately n comparisons.  Temporary
1266      * storage requirements vary from a small constant for nearly sorted
1267      * input arrays to n/2 object references for randomly ordered input
1268      * arrays.
1269      *
1270      * <p>The implementation takes equal advantage of ascending and
1271      * descending order in its input array, and can take advantage of
1272      * ascending and descending order in different parts of the same
1273      * input array.  It is well-suited to merging two or more sorted arrays:
1274      * simply concatenate the arrays and sort the resulting array.
1275      *
1276      * <p>The implementation was adapted from Tim Peters's list sort for Python
1277      * (<a href="http://svn.python.org/projects/python/trunk/Objects/listsort.txt">
1278      * TimSort</a>).  It uses techniques from Peter McIlroy's "Optimistic
1279      * Sorting and Information Theoretic Complexity", in Proceedings of the
1280      * Fourth Annual ACM-SIAM Symposium on Discrete Algorithms, pp 467-474,
1281      * January 1993.
1282      *
1283      * @param <T> the class of the objects to be sorted
1284      * @param a the array to be sorted
1285      * @param fromIndex the index of the first element (inclusive) to be
1286      *        sorted
1287      * @param toIndex the index of the last element (exclusive) to be sorted
1288      * @param c the comparator to determine the order of the array.  A
1289      *        {@code null} value indicates that the elements'
1290      *        {@linkplain Comparable natural ordering} should be used.
1291      * @throws ClassCastException if the array contains elements that are not
1292      *         <i>mutually comparable</i> using the specified comparator.
1293      * @throws IllegalArgumentException if {@code fromIndex > toIndex} or
1294      *         (optional) if the comparator is found to violate the
1295      *         {@link Comparator} contract
1296      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
1297      *         {@code toIndex > a.length}
1298      */
1299     public static <T> void sort(T[] a, int fromIndex, int toIndex,
1300                                 Comparator<? super T> c) {
1301         if (c == null) {
1302             sort(a, fromIndex, toIndex);
1303         } else {
1304             rangeCheck(a.length, fromIndex, toIndex);
1305             if (LegacyMergeSort.userRequested)
1306                 legacyMergeSort(a, fromIndex, toIndex, c);
1307             else
1308                 TimSort.sort(a, fromIndex, toIndex, c, null, 0, 0);
1309         }
1310     }
1311 
1312     /** To be removed in a future release. */
1313     private static <T> void legacyMergeSort(T[] a, int fromIndex, int toIndex,
1314                                             Comparator<? super T> c) {
1315         T[] aux = copyOfRange(a, fromIndex, toIndex);
1316         if (c==null)
1317             mergeSort(aux, a, fromIndex, toIndex, -fromIndex);
1318         else
1319             mergeSort(aux, a, fromIndex, toIndex, -fromIndex, c);
1320     }
1321 
1322     /**
1323      * Src is the source array that starts at index 0
1324      * Dest is the (possibly larger) array destination with a possible offset
1325      * low is the index in dest to start sorting
1326      * high is the end index in dest to end sorting
1327      * off is the offset into src corresponding to low in dest
1328      * To be removed in a future release.
1329      */
1330     @SuppressWarnings({"rawtypes", "unchecked"})
1331     private static void mergeSort(Object[] src,
1332                                   Object[] dest,
1333                                   int low, int high, int off,
1334                                   Comparator c) {
1335         int length = high - low;
1336 
1337         // Insertion sort on smallest arrays
1338         if (length < INSERTIONSORT_THRESHOLD) {
1339             for (int i=low; i<high; i++)
1340                 for (int j=i; j>low && c.compare(dest[j-1], dest[j])>0; j--)
1341                     swap(dest, j, j-1);
1342             return;
1343         }
1344 
1345         // Recursively sort halves of dest into src
1346         int destLow  = low;
1347         int destHigh = high;
1348         low  += off;
1349         high += off;
1350         int mid = (low + high) >>> 1;
1351         mergeSort(dest, src, low, mid, -off, c);
1352         mergeSort(dest, src, mid, high, -off, c);
1353 
1354         // If list is already sorted, just copy from src to dest.  This is an
1355         // optimization that results in faster sorts for nearly ordered lists.
1356         if (c.compare(src[mid-1], src[mid]) <= 0) {
1357            System.arraycopy(src, low, dest, destLow, length);
1358            return;
1359         }
1360 
1361         // Merge sorted halves (now in src) into dest
1362         for(int i = destLow, p = low, q = mid; i < destHigh; i++) {
1363             if (q >= high || p < mid && c.compare(src[p], src[q]) <= 0)
1364                 dest[i] = src[p++];
1365             else
1366                 dest[i] = src[q++];
1367         }
1368     }
1369 
1370     // Parallel prefix
1371 
1372     /**
1373      * Cumulates, in parallel, each element of the given array in place,
1374      * using the supplied function. For example if the array initially
1375      * holds {@code [2, 1, 0, 3]} and the operation performs addition,
1376      * then upon return the array holds {@code [2, 3, 3, 6]}.
1377      * Parallel prefix computation is usually more efficient than
1378      * sequential loops for large arrays.
1379      *
1380      * @param <T> the class of the objects in the array
1381      * @param array the array, which is modified in-place by this method
1382      * @param op a side-effect-free, associative function to perform the
1383      * cumulation
1384      * @throws NullPointerException if the specified array or function is null
1385      * @since 1.8
1386      */
1387     public static <T> void parallelPrefix(T[] array, BinaryOperator<T> op) {
1388         Objects.requireNonNull(op);
1389         if (array.length > 0)
1390             new ArrayPrefixHelpers.CumulateTask<>
1391                     (null, op, array, 0, array.length).invoke();
1392     }
1393 
1394     /**
1395      * Performs {@link #parallelPrefix(Object[], BinaryOperator)}
1396      * for the given subrange of the array.
1397      *
1398      * @param <T> the class of the objects in the array
1399      * @param array the array
1400      * @param fromIndex the index of the first element, inclusive
1401      * @param toIndex the index of the last element, exclusive
1402      * @param op a side-effect-free, associative function to perform the
1403      * cumulation
1404      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
1405      * @throws ArrayIndexOutOfBoundsException
1406      *     if {@code fromIndex < 0} or {@code toIndex > array.length}
1407      * @throws NullPointerException if the specified array or function is null
1408      * @since 1.8
1409      */
1410     public static <T> void parallelPrefix(T[] array, int fromIndex,
1411                                           int toIndex, BinaryOperator<T> op) {
1412         Objects.requireNonNull(op);
1413         rangeCheck(array.length, fromIndex, toIndex);
1414         if (fromIndex < toIndex)
1415             new ArrayPrefixHelpers.CumulateTask<>
1416                     (null, op, array, fromIndex, toIndex).invoke();
1417     }
1418 
1419     /**
1420      * Cumulates, in parallel, each element of the given array in place,
1421      * using the supplied function. For example if the array initially
1422      * holds {@code [2, 1, 0, 3]} and the operation performs addition,
1423      * then upon return the array holds {@code [2, 3, 3, 6]}.
1424      * Parallel prefix computation is usually more efficient than
1425      * sequential loops for large arrays.
1426      *
1427      * @param array the array, which is modified in-place by this method
1428      * @param op a side-effect-free, associative function to perform the
1429      * cumulation
1430      * @throws NullPointerException if the specified array or function is null
1431      * @since 1.8
1432      */
1433     public static void parallelPrefix(long[] array, LongBinaryOperator op) {
1434         Objects.requireNonNull(op);
1435         if (array.length > 0)
1436             new ArrayPrefixHelpers.LongCumulateTask
1437                     (null, op, array, 0, array.length).invoke();
1438     }
1439 
1440     /**
1441      * Performs {@link #parallelPrefix(long[], LongBinaryOperator)}
1442      * for the given subrange of the array.
1443      *
1444      * @param array the array
1445      * @param fromIndex the index of the first element, inclusive
1446      * @param toIndex the index of the last element, exclusive
1447      * @param op a side-effect-free, associative function to perform the
1448      * cumulation
1449      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
1450      * @throws ArrayIndexOutOfBoundsException
1451      *     if {@code fromIndex < 0} or {@code toIndex > array.length}
1452      * @throws NullPointerException if the specified array or function is null
1453      * @since 1.8
1454      */
1455     public static void parallelPrefix(long[] array, int fromIndex,
1456                                       int toIndex, LongBinaryOperator op) {
1457         Objects.requireNonNull(op);
1458         rangeCheck(array.length, fromIndex, toIndex);
1459         if (fromIndex < toIndex)
1460             new ArrayPrefixHelpers.LongCumulateTask
1461                     (null, op, array, fromIndex, toIndex).invoke();
1462     }
1463 
1464     /**
1465      * Cumulates, in parallel, each element of the given array in place,
1466      * using the supplied function. For example if the array initially
1467      * holds {@code [2.0, 1.0, 0.0, 3.0]} and the operation performs addition,
1468      * then upon return the array holds {@code [2.0, 3.0, 3.0, 6.0]}.
1469      * Parallel prefix computation is usually more efficient than
1470      * sequential loops for large arrays.
1471      *
1472      * <p> Because floating-point operations may not be strictly associative,
1473      * the returned result may not be identical to the value that would be
1474      * obtained if the operation was performed sequentially.
1475      *
1476      * @param array the array, which is modified in-place by this method
1477      * @param op a side-effect-free function to perform the cumulation
1478      * @throws NullPointerException if the specified array or function is null
1479      * @since 1.8
1480      */
1481     public static void parallelPrefix(double[] array, DoubleBinaryOperator op) {
1482         Objects.requireNonNull(op);
1483         if (array.length > 0)
1484             new ArrayPrefixHelpers.DoubleCumulateTask
1485                     (null, op, array, 0, array.length).invoke();
1486     }
1487 
1488     /**
1489      * Performs {@link #parallelPrefix(double[], DoubleBinaryOperator)}
1490      * for the given subrange of the array.
1491      *
1492      * @param array the array
1493      * @param fromIndex the index of the first element, inclusive
1494      * @param toIndex the index of the last element, exclusive
1495      * @param op a side-effect-free, associative function to perform the
1496      * cumulation
1497      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
1498      * @throws ArrayIndexOutOfBoundsException
1499      *     if {@code fromIndex < 0} or {@code toIndex > array.length}
1500      * @throws NullPointerException if the specified array or function is null
1501      * @since 1.8
1502      */
1503     public static void parallelPrefix(double[] array, int fromIndex,
1504                                       int toIndex, DoubleBinaryOperator op) {
1505         Objects.requireNonNull(op);
1506         rangeCheck(array.length, fromIndex, toIndex);
1507         if (fromIndex < toIndex)
1508             new ArrayPrefixHelpers.DoubleCumulateTask
1509                     (null, op, array, fromIndex, toIndex).invoke();
1510     }
1511 
1512     /**
1513      * Cumulates, in parallel, each element of the given array in place,
1514      * using the supplied function. For example if the array initially
1515      * holds {@code [2, 1, 0, 3]} and the operation performs addition,
1516      * then upon return the array holds {@code [2, 3, 3, 6]}.
1517      * Parallel prefix computation is usually more efficient than
1518      * sequential loops for large arrays.
1519      *
1520      * @param array the array, which is modified in-place by this method
1521      * @param op a side-effect-free, associative function to perform the
1522      * cumulation
1523      * @throws NullPointerException if the specified array or function is null
1524      * @since 1.8
1525      */
1526     public static void parallelPrefix(int[] array, IntBinaryOperator op) {
1527         Objects.requireNonNull(op);
1528         if (array.length > 0)
1529             new ArrayPrefixHelpers.IntCumulateTask
1530                     (null, op, array, 0, array.length).invoke();
1531     }
1532 
1533     /**
1534      * Performs {@link #parallelPrefix(int[], IntBinaryOperator)}
1535      * for the given subrange of the array.
1536      *
1537      * @param array the array
1538      * @param fromIndex the index of the first element, inclusive
1539      * @param toIndex the index of the last element, exclusive
1540      * @param op a side-effect-free, associative function to perform the
1541      * cumulation
1542      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
1543      * @throws ArrayIndexOutOfBoundsException
1544      *     if {@code fromIndex < 0} or {@code toIndex > array.length}
1545      * @throws NullPointerException if the specified array or function is null
1546      * @since 1.8
1547      */
1548     public static void parallelPrefix(int[] array, int fromIndex,
1549                                       int toIndex, IntBinaryOperator op) {
1550         Objects.requireNonNull(op);
1551         rangeCheck(array.length, fromIndex, toIndex);
1552         if (fromIndex < toIndex)
1553             new ArrayPrefixHelpers.IntCumulateTask
1554                     (null, op, array, fromIndex, toIndex).invoke();
1555     }
1556 
1557     // Searching
1558 
1559     /**
1560      * Searches the specified array of longs for the specified value using the
1561      * binary search algorithm.  The array must be sorted (as
1562      * by the {@link #sort(long[])} method) prior to making this call.  If it
1563      * is not sorted, the results are undefined.  If the array contains
1564      * multiple elements with the specified value, there is no guarantee which
1565      * one will be found.
1566      *
1567      * @param a the array to be searched
1568      * @param key the value to be searched for
1569      * @return index of the search key, if it is contained in the array;
1570      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1571      *         <i>insertion point</i> is defined as the point at which the
1572      *         key would be inserted into the array: the index of the first
1573      *         element greater than the key, or {@code a.length} if all
1574      *         elements in the array are less than the specified key.  Note
1575      *         that this guarantees that the return value will be &gt;= 0 if
1576      *         and only if the key is found.
1577      */
1578     public static int binarySearch(long[] a, long key) {
1579         return binarySearch0(a, 0, a.length, key);
1580     }
1581 
1582     /**
1583      * Searches a range of
1584      * the specified array of longs for the specified value using the
1585      * binary search algorithm.
1586      * The range must be sorted (as
1587      * by the {@link #sort(long[], int, int)} method)
1588      * prior to making this call.  If it
1589      * is not sorted, the results are undefined.  If the range contains
1590      * multiple elements with the specified value, there is no guarantee which
1591      * one will be found.
1592      *
1593      * @param a the array to be searched
1594      * @param fromIndex the index of the first element (inclusive) to be
1595      *          searched
1596      * @param toIndex the index of the last element (exclusive) to be searched
1597      * @param key the value to be searched for
1598      * @return index of the search key, if it is contained in the array
1599      *         within the specified range;
1600      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1601      *         <i>insertion point</i> is defined as the point at which the
1602      *         key would be inserted into the array: the index of the first
1603      *         element in the range greater than the key,
1604      *         or {@code toIndex} if all
1605      *         elements in the range are less than the specified key.  Note
1606      *         that this guarantees that the return value will be &gt;= 0 if
1607      *         and only if the key is found.
1608      * @throws IllegalArgumentException
1609      *         if {@code fromIndex > toIndex}
1610      * @throws ArrayIndexOutOfBoundsException
1611      *         if {@code fromIndex < 0 or toIndex > a.length}
1612      * @since 1.6
1613      */
1614     public static int binarySearch(long[] a, int fromIndex, int toIndex,
1615                                    long key) {
1616         rangeCheck(a.length, fromIndex, toIndex);
1617         return binarySearch0(a, fromIndex, toIndex, key);
1618     }
1619 
1620     // Like public version, but without range checks.
1621     private static int binarySearch0(long[] a, int fromIndex, int toIndex,
1622                                      long key) {
1623         int low = fromIndex;
1624         int high = toIndex - 1;
1625 
1626         while (low <= high) {
1627             int mid = (low + high) >>> 1;
1628             long midVal = a[mid];
1629 
1630             if (midVal < key)
1631                 low = mid + 1;
1632             else if (midVal > key)
1633                 high = mid - 1;
1634             else
1635                 return mid; // key found
1636         }
1637         return -(low + 1);  // key not found.
1638     }
1639 
1640     /**
1641      * Searches the specified array of ints for the specified value using the
1642      * binary search algorithm.  The array must be sorted (as
1643      * by the {@link #sort(int[])} method) prior to making this call.  If it
1644      * is not sorted, the results are undefined.  If the array contains
1645      * multiple elements with the specified value, there is no guarantee which
1646      * one will be found.
1647      *
1648      * @param a the array to be searched
1649      * @param key the value to be searched for
1650      * @return index of the search key, if it is contained in the array;
1651      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1652      *         <i>insertion point</i> is defined as the point at which the
1653      *         key would be inserted into the array: the index of the first
1654      *         element greater than the key, or {@code a.length} if all
1655      *         elements in the array are less than the specified key.  Note
1656      *         that this guarantees that the return value will be &gt;= 0 if
1657      *         and only if the key is found.
1658      */
1659     public static int binarySearch(int[] a, int key) {
1660         return binarySearch0(a, 0, a.length, key);
1661     }
1662 
1663     /**
1664      * Searches a range of
1665      * the specified array of ints for the specified value using the
1666      * binary search algorithm.
1667      * The range must be sorted (as
1668      * by the {@link #sort(int[], int, int)} method)
1669      * prior to making this call.  If it
1670      * is not sorted, the results are undefined.  If the range contains
1671      * multiple elements with the specified value, there is no guarantee which
1672      * one will be found.
1673      *
1674      * @param a the array to be searched
1675      * @param fromIndex the index of the first element (inclusive) to be
1676      *          searched
1677      * @param toIndex the index of the last element (exclusive) to be searched
1678      * @param key the value to be searched for
1679      * @return index of the search key, if it is contained in the array
1680      *         within the specified range;
1681      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1682      *         <i>insertion point</i> is defined as the point at which the
1683      *         key would be inserted into the array: the index of the first
1684      *         element in the range greater than the key,
1685      *         or {@code toIndex} if all
1686      *         elements in the range are less than the specified key.  Note
1687      *         that this guarantees that the return value will be &gt;= 0 if
1688      *         and only if the key is found.
1689      * @throws IllegalArgumentException
1690      *         if {@code fromIndex > toIndex}
1691      * @throws ArrayIndexOutOfBoundsException
1692      *         if {@code fromIndex < 0 or toIndex > a.length}
1693      * @since 1.6
1694      */
1695     public static int binarySearch(int[] a, int fromIndex, int toIndex,
1696                                    int key) {
1697         rangeCheck(a.length, fromIndex, toIndex);
1698         return binarySearch0(a, fromIndex, toIndex, key);
1699     }
1700 
1701     // Like public version, but without range checks.
1702     private static int binarySearch0(int[] a, int fromIndex, int toIndex,
1703                                      int key) {
1704         int low = fromIndex;
1705         int high = toIndex - 1;
1706 
1707         while (low <= high) {
1708             int mid = (low + high) >>> 1;
1709             int midVal = a[mid];
1710 
1711             if (midVal < key)
1712                 low = mid + 1;
1713             else if (midVal > key)
1714                 high = mid - 1;
1715             else
1716                 return mid; // key found
1717         }
1718         return -(low + 1);  // key not found.
1719     }
1720 
1721     /**
1722      * Searches the specified array of shorts for the specified value using
1723      * the binary search algorithm.  The array must be sorted
1724      * (as by the {@link #sort(short[])} method) prior to making this call.  If
1725      * it is not sorted, the results are undefined.  If the array contains
1726      * multiple elements with the specified value, there is no guarantee which
1727      * one will be found.
1728      *
1729      * @param a the array to be searched
1730      * @param key the value to be searched for
1731      * @return index of the search key, if it is contained in the array;
1732      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1733      *         <i>insertion point</i> is defined as the point at which the
1734      *         key would be inserted into the array: the index of the first
1735      *         element greater than the key, or {@code a.length} if all
1736      *         elements in the array are less than the specified key.  Note
1737      *         that this guarantees that the return value will be &gt;= 0 if
1738      *         and only if the key is found.
1739      */
1740     public static int binarySearch(short[] a, short key) {
1741         return binarySearch0(a, 0, a.length, key);
1742     }
1743 
1744     /**
1745      * Searches a range of
1746      * the specified array of shorts for the specified value using
1747      * the binary search algorithm.
1748      * The range must be sorted
1749      * (as by the {@link #sort(short[], int, int)} method)
1750      * prior to making this call.  If
1751      * it is not sorted, the results are undefined.  If the range contains
1752      * multiple elements with the specified value, there is no guarantee which
1753      * one will be found.
1754      *
1755      * @param a the array to be searched
1756      * @param fromIndex the index of the first element (inclusive) to be
1757      *          searched
1758      * @param toIndex the index of the last element (exclusive) to be searched
1759      * @param key the value to be searched for
1760      * @return index of the search key, if it is contained in the array
1761      *         within the specified range;
1762      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1763      *         <i>insertion point</i> is defined as the point at which the
1764      *         key would be inserted into the array: the index of the first
1765      *         element in the range greater than the key,
1766      *         or {@code toIndex} if all
1767      *         elements in the range are less than the specified key.  Note
1768      *         that this guarantees that the return value will be &gt;= 0 if
1769      *         and only if the key is found.
1770      * @throws IllegalArgumentException
1771      *         if {@code fromIndex > toIndex}
1772      * @throws ArrayIndexOutOfBoundsException
1773      *         if {@code fromIndex < 0 or toIndex > a.length}
1774      * @since 1.6
1775      */
1776     public static int binarySearch(short[] a, int fromIndex, int toIndex,
1777                                    short key) {
1778         rangeCheck(a.length, fromIndex, toIndex);
1779         return binarySearch0(a, fromIndex, toIndex, key);
1780     }
1781 
1782     // Like public version, but without range checks.
1783     private static int binarySearch0(short[] a, int fromIndex, int toIndex,
1784                                      short key) {
1785         int low = fromIndex;
1786         int high = toIndex - 1;
1787 
1788         while (low <= high) {
1789             int mid = (low + high) >>> 1;
1790             short midVal = a[mid];
1791 
1792             if (midVal < key)
1793                 low = mid + 1;
1794             else if (midVal > key)
1795                 high = mid - 1;
1796             else
1797                 return mid; // key found
1798         }
1799         return -(low + 1);  // key not found.
1800     }
1801 
1802     /**
1803      * Searches the specified array of chars for the specified value using the
1804      * binary search algorithm.  The array must be sorted (as
1805      * by the {@link #sort(char[])} method) prior to making this call.  If it
1806      * is not sorted, the results are undefined.  If the array contains
1807      * multiple elements with the specified value, there is no guarantee which
1808      * one will be found.
1809      *
1810      * @param a the array to be searched
1811      * @param key the value to be searched for
1812      * @return index of the search key, if it is contained in the array;
1813      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1814      *         <i>insertion point</i> is defined as the point at which the
1815      *         key would be inserted into the array: the index of the first
1816      *         element greater than the key, or {@code a.length} if all
1817      *         elements in the array are less than the specified key.  Note
1818      *         that this guarantees that the return value will be &gt;= 0 if
1819      *         and only if the key is found.
1820      */
1821     public static int binarySearch(char[] a, char key) {
1822         return binarySearch0(a, 0, a.length, key);
1823     }
1824 
1825     /**
1826      * Searches a range of
1827      * the specified array of chars for the specified value using the
1828      * binary search algorithm.
1829      * The range must be sorted (as
1830      * by the {@link #sort(char[], int, int)} method)
1831      * prior to making this call.  If it
1832      * is not sorted, the results are undefined.  If the range contains
1833      * multiple elements with the specified value, there is no guarantee which
1834      * one will be found.
1835      *
1836      * @param a the array to be searched
1837      * @param fromIndex the index of the first element (inclusive) to be
1838      *          searched
1839      * @param toIndex the index of the last element (exclusive) to be searched
1840      * @param key the value to be searched for
1841      * @return index of the search key, if it is contained in the array
1842      *         within the specified range;
1843      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1844      *         <i>insertion point</i> is defined as the point at which the
1845      *         key would be inserted into the array: the index of the first
1846      *         element in the range greater than the key,
1847      *         or {@code toIndex} if all
1848      *         elements in the range are less than the specified key.  Note
1849      *         that this guarantees that the return value will be &gt;= 0 if
1850      *         and only if the key is found.
1851      * @throws IllegalArgumentException
1852      *         if {@code fromIndex > toIndex}
1853      * @throws ArrayIndexOutOfBoundsException
1854      *         if {@code fromIndex < 0 or toIndex > a.length}
1855      * @since 1.6
1856      */
1857     public static int binarySearch(char[] a, int fromIndex, int toIndex,
1858                                    char key) {
1859         rangeCheck(a.length, fromIndex, toIndex);
1860         return binarySearch0(a, fromIndex, toIndex, key);
1861     }
1862 
1863     // Like public version, but without range checks.
1864     private static int binarySearch0(char[] a, int fromIndex, int toIndex,
1865                                      char key) {
1866         int low = fromIndex;
1867         int high = toIndex - 1;
1868 
1869         while (low <= high) {
1870             int mid = (low + high) >>> 1;
1871             char midVal = a[mid];
1872 
1873             if (midVal < key)
1874                 low = mid + 1;
1875             else if (midVal > key)
1876                 high = mid - 1;
1877             else
1878                 return mid; // key found
1879         }
1880         return -(low + 1);  // key not found.
1881     }
1882 
1883     /**
1884      * Searches the specified array of bytes for the specified value using the
1885      * binary search algorithm.  The array must be sorted (as
1886      * by the {@link #sort(byte[])} method) prior to making this call.  If it
1887      * is not sorted, the results are undefined.  If the array contains
1888      * multiple elements with the specified value, there is no guarantee which
1889      * one will be found.
1890      *
1891      * @param a the array to be searched
1892      * @param key the value to be searched for
1893      * @return index of the search key, if it is contained in the array;
1894      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1895      *         <i>insertion point</i> is defined as the point at which the
1896      *         key would be inserted into the array: the index of the first
1897      *         element greater than the key, or {@code a.length} if all
1898      *         elements in the array are less than the specified key.  Note
1899      *         that this guarantees that the return value will be &gt;= 0 if
1900      *         and only if the key is found.
1901      */
1902     public static int binarySearch(byte[] a, byte key) {
1903         return binarySearch0(a, 0, a.length, key);
1904     }
1905 
1906     /**
1907      * Searches a range of
1908      * the specified array of bytes for the specified value using the
1909      * binary search algorithm.
1910      * The range must be sorted (as
1911      * by the {@link #sort(byte[], int, int)} method)
1912      * prior to making this call.  If it
1913      * is not sorted, the results are undefined.  If the range contains
1914      * multiple elements with the specified value, there is no guarantee which
1915      * one will be found.
1916      *
1917      * @param a the array to be searched
1918      * @param fromIndex the index of the first element (inclusive) to be
1919      *          searched
1920      * @param toIndex the index of the last element (exclusive) to be searched
1921      * @param key the value to be searched for
1922      * @return index of the search key, if it is contained in the array
1923      *         within the specified range;
1924      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1925      *         <i>insertion point</i> is defined as the point at which the
1926      *         key would be inserted into the array: the index of the first
1927      *         element in the range greater than the key,
1928      *         or {@code toIndex} if all
1929      *         elements in the range are less than the specified key.  Note
1930      *         that this guarantees that the return value will be &gt;= 0 if
1931      *         and only if the key is found.
1932      * @throws IllegalArgumentException
1933      *         if {@code fromIndex > toIndex}
1934      * @throws ArrayIndexOutOfBoundsException
1935      *         if {@code fromIndex < 0 or toIndex > a.length}
1936      * @since 1.6
1937      */
1938     public static int binarySearch(byte[] a, int fromIndex, int toIndex,
1939                                    byte key) {
1940         rangeCheck(a.length, fromIndex, toIndex);
1941         return binarySearch0(a, fromIndex, toIndex, key);
1942     }
1943 
1944     // Like public version, but without range checks.
1945     private static int binarySearch0(byte[] a, int fromIndex, int toIndex,
1946                                      byte key) {
1947         int low = fromIndex;
1948         int high = toIndex - 1;
1949 
1950         while (low <= high) {
1951             int mid = (low + high) >>> 1;
1952             byte midVal = a[mid];
1953 
1954             if (midVal < key)
1955                 low = mid + 1;
1956             else if (midVal > key)
1957                 high = mid - 1;
1958             else
1959                 return mid; // key found
1960         }
1961         return -(low + 1);  // key not found.
1962     }
1963 
1964     /**
1965      * Searches the specified array of doubles for the specified value using
1966      * the binary search algorithm.  The array must be sorted
1967      * (as by the {@link #sort(double[])} method) prior to making this call.
1968      * If it is not sorted, the results are undefined.  If the array contains
1969      * multiple elements with the specified value, there is no guarantee which
1970      * one will be found.  This method considers all NaN values to be
1971      * equivalent and equal.
1972      *
1973      * @param a the array to be searched
1974      * @param key the value to be searched for
1975      * @return index of the search key, if it is contained in the array;
1976      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
1977      *         <i>insertion point</i> is defined as the point at which the
1978      *         key would be inserted into the array: the index of the first
1979      *         element greater than the key, or {@code a.length} if all
1980      *         elements in the array are less than the specified key.  Note
1981      *         that this guarantees that the return value will be &gt;= 0 if
1982      *         and only if the key is found.
1983      */
1984     public static int binarySearch(double[] a, double key) {
1985         return binarySearch0(a, 0, a.length, key);
1986     }
1987 
1988     /**
1989      * Searches a range of
1990      * the specified array of doubles for the specified value using
1991      * the binary search algorithm.
1992      * The range must be sorted
1993      * (as by the {@link #sort(double[], int, int)} method)
1994      * prior to making this call.
1995      * If it is not sorted, the results are undefined.  If the range contains
1996      * multiple elements with the specified value, there is no guarantee which
1997      * one will be found.  This method considers all NaN values to be
1998      * equivalent and equal.
1999      *
2000      * @param a the array to be searched
2001      * @param fromIndex the index of the first element (inclusive) to be
2002      *          searched
2003      * @param toIndex the index of the last element (exclusive) to be searched
2004      * @param key the value to be searched for
2005      * @return index of the search key, if it is contained in the array
2006      *         within the specified range;
2007      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
2008      *         <i>insertion point</i> is defined as the point at which the
2009      *         key would be inserted into the array: the index of the first
2010      *         element in the range greater than the key,
2011      *         or {@code toIndex} if all
2012      *         elements in the range are less than the specified key.  Note
2013      *         that this guarantees that the return value will be &gt;= 0 if
2014      *         and only if the key is found.
2015      * @throws IllegalArgumentException
2016      *         if {@code fromIndex > toIndex}
2017      * @throws ArrayIndexOutOfBoundsException
2018      *         if {@code fromIndex < 0 or toIndex > a.length}
2019      * @since 1.6
2020      */
2021     public static int binarySearch(double[] a, int fromIndex, int toIndex,
2022                                    double key) {
2023         rangeCheck(a.length, fromIndex, toIndex);
2024         return binarySearch0(a, fromIndex, toIndex, key);
2025     }
2026 
2027     // Like public version, but without range checks.
2028     private static int binarySearch0(double[] a, int fromIndex, int toIndex,
2029                                      double key) {
2030         int low = fromIndex;
2031         int high = toIndex - 1;
2032 
2033         while (low <= high) {
2034             int mid = (low + high) >>> 1;
2035             double midVal = a[mid];
2036 
2037             if (midVal < key)
2038                 low = mid + 1;  // Neither val is NaN, thisVal is smaller
2039             else if (midVal > key)
2040                 high = mid - 1; // Neither val is NaN, thisVal is larger
2041             else {
2042                 long midBits = Double.doubleToLongBits(midVal);
2043                 long keyBits = Double.doubleToLongBits(key);
2044                 if (midBits == keyBits)     // Values are equal
2045                     return mid;             // Key found
2046                 else if (midBits < keyBits) // (-0.0, 0.0) or (!NaN, NaN)
2047                     low = mid + 1;
2048                 else                        // (0.0, -0.0) or (NaN, !NaN)
2049                     high = mid - 1;
2050             }
2051         }
2052         return -(low + 1);  // key not found.
2053     }
2054 
2055     /**
2056      * Searches the specified array of floats for the specified value using
2057      * the binary search algorithm. The array must be sorted
2058      * (as by the {@link #sort(float[])} method) prior to making this call. If
2059      * it is not sorted, the results are undefined. If the array contains
2060      * multiple elements with the specified value, there is no guarantee which
2061      * one will be found. This method considers all NaN values to be
2062      * equivalent and equal.
2063      *
2064      * @param a the array to be searched
2065      * @param key the value to be searched for
2066      * @return index of the search key, if it is contained in the array;
2067      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>. The
2068      *         <i>insertion point</i> is defined as the point at which the
2069      *         key would be inserted into the array: the index of the first
2070      *         element greater than the key, or {@code a.length} if all
2071      *         elements in the array are less than the specified key. Note
2072      *         that this guarantees that the return value will be &gt;= 0 if
2073      *         and only if the key is found.
2074      */
2075     public static int binarySearch(float[] a, float key) {
2076         return binarySearch0(a, 0, a.length, key);
2077     }
2078 
2079     /**
2080      * Searches a range of
2081      * the specified array of floats for the specified value using
2082      * the binary search algorithm.
2083      * The range must be sorted
2084      * (as by the {@link #sort(float[], int, int)} method)
2085      * prior to making this call. If
2086      * it is not sorted, the results are undefined. If the range contains
2087      * multiple elements with the specified value, there is no guarantee which
2088      * one will be found. This method considers all NaN values to be
2089      * equivalent and equal.
2090      *
2091      * @param a the array to be searched
2092      * @param fromIndex the index of the first element (inclusive) to be
2093      *          searched
2094      * @param toIndex the index of the last element (exclusive) to be searched
2095      * @param key the value to be searched for
2096      * @return index of the search key, if it is contained in the array
2097      *         within the specified range;
2098      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>. The
2099      *         <i>insertion point</i> is defined as the point at which the
2100      *         key would be inserted into the array: the index of the first
2101      *         element in the range greater than the key,
2102      *         or {@code toIndex} if all
2103      *         elements in the range are less than the specified key. Note
2104      *         that this guarantees that the return value will be &gt;= 0 if
2105      *         and only if the key is found.
2106      * @throws IllegalArgumentException
2107      *         if {@code fromIndex > toIndex}
2108      * @throws ArrayIndexOutOfBoundsException
2109      *         if {@code fromIndex < 0 or toIndex > a.length}
2110      * @since 1.6
2111      */
2112     public static int binarySearch(float[] a, int fromIndex, int toIndex,
2113                                    float key) {
2114         rangeCheck(a.length, fromIndex, toIndex);
2115         return binarySearch0(a, fromIndex, toIndex, key);
2116     }
2117 
2118     // Like public version, but without range checks.
2119     private static int binarySearch0(float[] a, int fromIndex, int toIndex,
2120                                      float key) {
2121         int low = fromIndex;
2122         int high = toIndex - 1;
2123 
2124         while (low <= high) {
2125             int mid = (low + high) >>> 1;
2126             float midVal = a[mid];
2127 
2128             if (midVal < key)
2129                 low = mid + 1;  // Neither val is NaN, thisVal is smaller
2130             else if (midVal > key)
2131                 high = mid - 1; // Neither val is NaN, thisVal is larger
2132             else {
2133                 int midBits = Float.floatToIntBits(midVal);
2134                 int keyBits = Float.floatToIntBits(key);
2135                 if (midBits == keyBits)     // Values are equal
2136                     return mid;             // Key found
2137                 else if (midBits < keyBits) // (-0.0, 0.0) or (!NaN, NaN)
2138                     low = mid + 1;
2139                 else                        // (0.0, -0.0) or (NaN, !NaN)
2140                     high = mid - 1;
2141             }
2142         }
2143         return -(low + 1);  // key not found.
2144     }
2145 
2146     /**
2147      * Searches the specified array for the specified object using the binary
2148      * search algorithm. The array must be sorted into ascending order
2149      * according to the
2150      * {@linkplain Comparable natural ordering}
2151      * of its elements (as by the
2152      * {@link #sort(Object[])} method) prior to making this call.
2153      * If it is not sorted, the results are undefined.
2154      * (If the array contains elements that are not mutually comparable (for
2155      * example, strings and integers), it <i>cannot</i> be sorted according
2156      * to the natural ordering of its elements, hence results are undefined.)
2157      * If the array contains multiple
2158      * elements equal to the specified object, there is no guarantee which
2159      * one will be found.
2160      *
2161      * @param a the array to be searched
2162      * @param key the value to be searched for
2163      * @return index of the search key, if it is contained in the array;
2164      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
2165      *         <i>insertion point</i> is defined as the point at which the
2166      *         key would be inserted into the array: the index of the first
2167      *         element greater than the key, or {@code a.length} if all
2168      *         elements in the array are less than the specified key.  Note
2169      *         that this guarantees that the return value will be &gt;= 0 if
2170      *         and only if the key is found.
2171      * @throws ClassCastException if the search key is not comparable to the
2172      *         elements of the array.
2173      */
2174     public static int binarySearch(Object[] a, Object key) {
2175         return binarySearch0(a, 0, a.length, key);
2176     }
2177 
2178     /**
2179      * Searches a range of
2180      * the specified array for the specified object using the binary
2181      * search algorithm.
2182      * The range must be sorted into ascending order
2183      * according to the
2184      * {@linkplain Comparable natural ordering}
2185      * of its elements (as by the
2186      * {@link #sort(Object[], int, int)} method) prior to making this
2187      * call.  If it is not sorted, the results are undefined.
2188      * (If the range contains elements that are not mutually comparable (for
2189      * example, strings and integers), it <i>cannot</i> be sorted according
2190      * to the natural ordering of its elements, hence results are undefined.)
2191      * If the range contains multiple
2192      * elements equal to the specified object, there is no guarantee which
2193      * one will be found.
2194      *
2195      * @param a the array to be searched
2196      * @param fromIndex the index of the first element (inclusive) to be
2197      *          searched
2198      * @param toIndex the index of the last element (exclusive) to be searched
2199      * @param key the value to be searched for
2200      * @return index of the search key, if it is contained in the array
2201      *         within the specified range;
2202      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
2203      *         <i>insertion point</i> is defined as the point at which the
2204      *         key would be inserted into the array: the index of the first
2205      *         element in the range greater than the key,
2206      *         or {@code toIndex} if all
2207      *         elements in the range are less than the specified key.  Note
2208      *         that this guarantees that the return value will be &gt;= 0 if
2209      *         and only if the key is found.
2210      * @throws ClassCastException if the search key is not comparable to the
2211      *         elements of the array within the specified range.
2212      * @throws IllegalArgumentException
2213      *         if {@code fromIndex > toIndex}
2214      * @throws ArrayIndexOutOfBoundsException
2215      *         if {@code fromIndex < 0 or toIndex > a.length}
2216      * @since 1.6
2217      */
2218     public static int binarySearch(Object[] a, int fromIndex, int toIndex,
2219                                    Object key) {
2220         rangeCheck(a.length, fromIndex, toIndex);
2221         return binarySearch0(a, fromIndex, toIndex, key);
2222     }
2223 
2224     // Like public version, but without range checks.
2225     private static int binarySearch0(Object[] a, int fromIndex, int toIndex,
2226                                      Object key) {
2227         int low = fromIndex;
2228         int high = toIndex - 1;
2229 
2230         while (low <= high) {
2231             int mid = (low + high) >>> 1;
2232             @SuppressWarnings("rawtypes")
2233             Comparable midVal = (Comparable)a[mid];
2234             @SuppressWarnings("unchecked")
2235             int cmp = midVal.compareTo(key);
2236 
2237             if (cmp < 0)
2238                 low = mid + 1;
2239             else if (cmp > 0)
2240                 high = mid - 1;
2241             else
2242                 return mid; // key found
2243         }
2244         return -(low + 1);  // key not found.
2245     }
2246 
2247     /**
2248      * Searches the specified array for the specified object using the binary
2249      * search algorithm.  The array must be sorted into ascending order
2250      * according to the specified comparator (as by the
2251      * {@link #sort(Object[], Comparator) sort(T[], Comparator)}
2252      * method) prior to making this call.  If it is
2253      * not sorted, the results are undefined.
2254      * If the array contains multiple
2255      * elements equal to the specified object, there is no guarantee which one
2256      * will be found.
2257      *
2258      * @param <T> the class of the objects in the array
2259      * @param a the array to be searched
2260      * @param key the value to be searched for
2261      * @param c the comparator by which the array is ordered.  A
2262      *        {@code null} value indicates that the elements'
2263      *        {@linkplain Comparable natural ordering} should be used.
2264      * @return index of the search key, if it is contained in the array;
2265      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
2266      *         <i>insertion point</i> is defined as the point at which the
2267      *         key would be inserted into the array: the index of the first
2268      *         element greater than the key, or {@code a.length} if all
2269      *         elements in the array are less than the specified key.  Note
2270      *         that this guarantees that the return value will be &gt;= 0 if
2271      *         and only if the key is found.
2272      * @throws ClassCastException if the array contains elements that are not
2273      *         <i>mutually comparable</i> using the specified comparator,
2274      *         or the search key is not comparable to the
2275      *         elements of the array using this comparator.
2276      */
2277     public static <T> int binarySearch(T[] a, T key, Comparator<? super T> c) {
2278         return binarySearch0(a, 0, a.length, key, c);
2279     }
2280 
2281     /**
2282      * Searches a range of
2283      * the specified array for the specified object using the binary
2284      * search algorithm.
2285      * The range must be sorted into ascending order
2286      * according to the specified comparator (as by the
2287      * {@link #sort(Object[], int, int, Comparator)
2288      * sort(T[], int, int, Comparator)}
2289      * method) prior to making this call.
2290      * If it is not sorted, the results are undefined.
2291      * If the range contains multiple elements equal to the specified object,
2292      * there is no guarantee which one will be found.
2293      *
2294      * @param <T> the class of the objects in the array
2295      * @param a the array to be searched
2296      * @param fromIndex the index of the first element (inclusive) to be
2297      *          searched
2298      * @param toIndex the index of the last element (exclusive) to be searched
2299      * @param key the value to be searched for
2300      * @param c the comparator by which the array is ordered.  A
2301      *        {@code null} value indicates that the elements'
2302      *        {@linkplain Comparable natural ordering} should be used.
2303      * @return index of the search key, if it is contained in the array
2304      *         within the specified range;
2305      *         otherwise, <code>(-(<i>insertion point</i>) - 1)</code>.  The
2306      *         <i>insertion point</i> is defined as the point at which the
2307      *         key would be inserted into the array: the index of the first
2308      *         element in the range greater than the key,
2309      *         or {@code toIndex} if all
2310      *         elements in the range are less than the specified key.  Note
2311      *         that this guarantees that the return value will be &gt;= 0 if
2312      *         and only if the key is found.
2313      * @throws ClassCastException if the range contains elements that are not
2314      *         <i>mutually comparable</i> using the specified comparator,
2315      *         or the search key is not comparable to the
2316      *         elements in the range using this comparator.
2317      * @throws IllegalArgumentException
2318      *         if {@code fromIndex > toIndex}
2319      * @throws ArrayIndexOutOfBoundsException
2320      *         if {@code fromIndex < 0 or toIndex > a.length}
2321      * @since 1.6
2322      */
2323     public static <T> int binarySearch(T[] a, int fromIndex, int toIndex,
2324                                        T key, Comparator<? super T> c) {
2325         rangeCheck(a.length, fromIndex, toIndex);
2326         return binarySearch0(a, fromIndex, toIndex, key, c);
2327     }
2328 
2329     // Like public version, but without range checks.
2330     private static <T> int binarySearch0(T[] a, int fromIndex, int toIndex,
2331                                          T key, Comparator<? super T> c) {
2332         if (c == null) {
2333             return binarySearch0(a, fromIndex, toIndex, key);
2334         }
2335         int low = fromIndex;
2336         int high = toIndex - 1;
2337 
2338         while (low <= high) {
2339             int mid = (low + high) >>> 1;
2340             T midVal = a[mid];
2341             int cmp = c.compare(midVal, key);
2342             if (cmp < 0)
2343                 low = mid + 1;
2344             else if (cmp > 0)
2345                 high = mid - 1;
2346             else
2347                 return mid; // key found
2348         }
2349         return -(low + 1);  // key not found.
2350     }
2351 
2352     // Equality Testing
2353 
2354     /**
2355      * Returns {@code true} if the two specified arrays of longs are
2356      * <i>equal</i> to one another.  Two arrays are considered equal if both
2357      * arrays contain the same number of elements, and all corresponding pairs
2358      * of elements in the two arrays are equal.  In other words, two arrays
2359      * are equal if they contain the same elements in the same order.  Also,
2360      * two array references are considered equal if both are {@code null}.
2361      *
2362      * @param a one array to be tested for equality
2363      * @param a2 the other array to be tested for equality
2364      * @return {@code true} if the two arrays are equal
2365      */
2366     public static boolean equals(long[] a, long[] a2) {
2367         if (a==a2)
2368             return true;
2369         if (a==null || a2==null)
2370             return false;
2371 
2372         int length = a.length;
2373         if (a2.length != length)
2374             return false;
2375 
2376         return ArraysSupport.mismatch(a, a2, length) < 0;
2377     }
2378 
2379     /**
2380      * Returns true if the two specified arrays of longs, over the specified
2381      * ranges, are <i>equal</i> to one another.
2382      *
2383      * <p>Two arrays are considered equal if the number of elements covered by
2384      * each range is the same, and all corresponding pairs of elements over the
2385      * specified ranges in the two arrays are equal.  In other words, two arrays
2386      * are equal if they contain, over the specified ranges, the same elements
2387      * in the same order.
2388      *
2389      * @param a the first array to be tested for equality
2390      * @param aFromIndex the index (inclusive) of the first element in the
2391      *                   first array to be tested
2392      * @param aToIndex the index (exclusive) of the last element in the
2393      *                 first array to be tested
2394      * @param b the second array to be tested for equality
2395      * @param bFromIndex the index (inclusive) of the first element in the
2396      *                   second array to be tested
2397      * @param bToIndex the index (exclusive) of the last element in the
2398      *                 second array to be tested
2399      * @return {@code true} if the two arrays, over the specified ranges, are
2400      *         equal
2401      * @throws IllegalArgumentException
2402      *         if {@code aFromIndex > aToIndex} or
2403      *         if {@code bFromIndex > bToIndex}
2404      * @throws ArrayIndexOutOfBoundsException
2405      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2406      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2407      * @throws NullPointerException
2408      *         if either array is {@code null}
2409      * @since 9
2410      */
2411     public static boolean equals(long[] a, int aFromIndex, int aToIndex,
2412                                  long[] b, int bFromIndex, int bToIndex) {
2413         rangeCheck(a.length, aFromIndex, aToIndex);
2414         rangeCheck(b.length, bFromIndex, bToIndex);
2415 
2416         int aLength = aToIndex - aFromIndex;
2417         int bLength = bToIndex - bFromIndex;
2418         if (aLength != bLength)
2419             return false;
2420 
2421         return ArraysSupport.mismatch(a, aFromIndex,
2422                                       b, bFromIndex,
2423                                       aLength) < 0;
2424     }
2425 
2426     /**
2427      * Returns {@code true} if the two specified arrays of ints are
2428      * <i>equal</i> to one another.  Two arrays are considered equal if both
2429      * arrays contain the same number of elements, and all corresponding pairs
2430      * of elements in the two arrays are equal.  In other words, two arrays
2431      * are equal if they contain the same elements in the same order.  Also,
2432      * two array references are considered equal if both are {@code null}.
2433      *
2434      * @param a one array to be tested for equality
2435      * @param a2 the other array to be tested for equality
2436      * @return {@code true} if the two arrays are equal
2437      */
2438     public static boolean equals(int[] a, int[] a2) {
2439         if (a==a2)
2440             return true;
2441         if (a==null || a2==null)
2442             return false;
2443 
2444         int length = a.length;
2445         if (a2.length != length)
2446             return false;
2447 
2448         return ArraysSupport.mismatch(a, a2, length) < 0;
2449     }
2450 
2451     /**
2452      * Returns true if the two specified arrays of ints, over the specified
2453      * ranges, are <i>equal</i> to one another.
2454      *
2455      * <p>Two arrays are considered equal if the number of elements covered by
2456      * each range is the same, and all corresponding pairs of elements over the
2457      * specified ranges in the two arrays are equal.  In other words, two arrays
2458      * are equal if they contain, over the specified ranges, the same elements
2459      * in the same order.
2460      *
2461      * @param a the first array to be tested for equality
2462      * @param aFromIndex the index (inclusive) of the first element in the
2463      *                   first array to be tested
2464      * @param aToIndex the index (exclusive) of the last element in the
2465      *                 first array to be tested
2466      * @param b the second array to be tested for equality
2467      * @param bFromIndex the index (inclusive) of the first element in the
2468      *                   second array to be tested
2469      * @param bToIndex the index (exclusive) of the last element in the
2470      *                 second array to be tested
2471      * @return {@code true} if the two arrays, over the specified ranges, are
2472      *         equal
2473      * @throws IllegalArgumentException
2474      *         if {@code aFromIndex > aToIndex} or
2475      *         if {@code bFromIndex > bToIndex}
2476      * @throws ArrayIndexOutOfBoundsException
2477      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2478      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2479      * @throws NullPointerException
2480      *         if either array is {@code null}
2481      * @since 9
2482      */
2483     public static boolean equals(int[] a, int aFromIndex, int aToIndex,
2484                                  int[] b, int bFromIndex, int bToIndex) {
2485         rangeCheck(a.length, aFromIndex, aToIndex);
2486         rangeCheck(b.length, bFromIndex, bToIndex);
2487 
2488         int aLength = aToIndex - aFromIndex;
2489         int bLength = bToIndex - bFromIndex;
2490         if (aLength != bLength)
2491             return false;
2492 
2493         return ArraysSupport.mismatch(a, aFromIndex,
2494                                       b, bFromIndex,
2495                                       aLength) < 0;
2496     }
2497 
2498     /**
2499      * Returns {@code true} if the two specified arrays of shorts are
2500      * <i>equal</i> to one another.  Two arrays are considered equal if both
2501      * arrays contain the same number of elements, and all corresponding pairs
2502      * of elements in the two arrays are equal.  In other words, two arrays
2503      * are equal if they contain the same elements in the same order.  Also,
2504      * two array references are considered equal if both are {@code null}.
2505      *
2506      * @param a one array to be tested for equality
2507      * @param a2 the other array to be tested for equality
2508      * @return {@code true} if the two arrays are equal
2509      */
2510     public static boolean equals(short[] a, short[] a2) {
2511         if (a==a2)
2512             return true;
2513         if (a==null || a2==null)
2514             return false;
2515 
2516         int length = a.length;
2517         if (a2.length != length)
2518             return false;
2519 
2520         return ArraysSupport.mismatch(a, a2, length) < 0;
2521     }
2522 
2523     /**
2524      * Returns true if the two specified arrays of shorts, over the specified
2525      * ranges, are <i>equal</i> to one another.
2526      *
2527      * <p>Two arrays are considered equal if the number of elements covered by
2528      * each range is the same, and all corresponding pairs of elements over the
2529      * specified ranges in the two arrays are equal.  In other words, two arrays
2530      * are equal if they contain, over the specified ranges, the same elements
2531      * in the same order.
2532      *
2533      * @param a the first array to be tested for equality
2534      * @param aFromIndex the index (inclusive) of the first element in the
2535      *                   first array to be tested
2536      * @param aToIndex the index (exclusive) of the last element in the
2537      *                 first array to be tested
2538      * @param b the second array to be tested for equality
2539      * @param bFromIndex the index (inclusive) of the first element in the
2540      *                   second array to be tested
2541      * @param bToIndex the index (exclusive) of the last element in the
2542      *                 second array to be tested
2543      * @return {@code true} if the two arrays, over the specified ranges, are
2544      *         equal
2545      * @throws IllegalArgumentException
2546      *         if {@code aFromIndex > aToIndex} or
2547      *         if {@code bFromIndex > bToIndex}
2548      * @throws ArrayIndexOutOfBoundsException
2549      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2550      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2551      * @throws NullPointerException
2552      *         if either array is {@code null}
2553      * @since 9
2554      */
2555     public static boolean equals(short[] a, int aFromIndex, int aToIndex,
2556                                  short[] b, int bFromIndex, int bToIndex) {
2557         rangeCheck(a.length, aFromIndex, aToIndex);
2558         rangeCheck(b.length, bFromIndex, bToIndex);
2559 
2560         int aLength = aToIndex - aFromIndex;
2561         int bLength = bToIndex - bFromIndex;
2562         if (aLength != bLength)
2563             return false;
2564 
2565         return ArraysSupport.mismatch(a, aFromIndex,
2566                                       b, bFromIndex,
2567                                       aLength) < 0;
2568     }
2569 
2570     /**
2571      * Returns {@code true} if the two specified arrays of chars are
2572      * <i>equal</i> to one another.  Two arrays are considered equal if both
2573      * arrays contain the same number of elements, and all corresponding pairs
2574      * of elements in the two arrays are equal.  In other words, two arrays
2575      * are equal if they contain the same elements in the same order.  Also,
2576      * two array references are considered equal if both are {@code null}.
2577      *
2578      * @param a one array to be tested for equality
2579      * @param a2 the other array to be tested for equality
2580      * @return {@code true} if the two arrays are equal
2581      */
2582     @IntrinsicCandidate
2583     public static boolean equals(char[] a, char[] a2) {
2584         if (a==a2)
2585             return true;
2586         if (a==null || a2==null)
2587             return false;
2588 
2589         int length = a.length;
2590         if (a2.length != length)
2591             return false;
2592 
2593         return ArraysSupport.mismatch(a, a2, length) < 0;
2594     }
2595 
2596     /**
2597      * Returns true if the two specified arrays of chars, over the specified
2598      * ranges, are <i>equal</i> to one another.
2599      *
2600      * <p>Two arrays are considered equal if the number of elements covered by
2601      * each range is the same, and all corresponding pairs of elements over the
2602      * specified ranges in the two arrays are equal.  In other words, two arrays
2603      * are equal if they contain, over the specified ranges, the same elements
2604      * in the same order.
2605      *
2606      * @param a the first array to be tested for equality
2607      * @param aFromIndex the index (inclusive) of the first element in the
2608      *                   first array to be tested
2609      * @param aToIndex the index (exclusive) of the last element in the
2610      *                 first array to be tested
2611      * @param b the second array to be tested for equality
2612      * @param bFromIndex the index (inclusive) of the first element in the
2613      *                   second array to be tested
2614      * @param bToIndex the index (exclusive) of the last element in the
2615      *                 second array to be tested
2616      * @return {@code true} if the two arrays, over the specified ranges, are
2617      *         equal
2618      * @throws IllegalArgumentException
2619      *         if {@code aFromIndex > aToIndex} or
2620      *         if {@code bFromIndex > bToIndex}
2621      * @throws ArrayIndexOutOfBoundsException
2622      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2623      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2624      * @throws NullPointerException
2625      *         if either array is {@code null}
2626      * @since 9
2627      */
2628     public static boolean equals(char[] a, int aFromIndex, int aToIndex,
2629                                  char[] b, int bFromIndex, int bToIndex) {
2630         rangeCheck(a.length, aFromIndex, aToIndex);
2631         rangeCheck(b.length, bFromIndex, bToIndex);
2632 
2633         int aLength = aToIndex - aFromIndex;
2634         int bLength = bToIndex - bFromIndex;
2635         if (aLength != bLength)
2636             return false;
2637 
2638         return ArraysSupport.mismatch(a, aFromIndex,
2639                                       b, bFromIndex,
2640                                       aLength) < 0;
2641     }
2642 
2643     /**
2644      * Returns {@code true} if the two specified arrays of bytes are
2645      * <i>equal</i> to one another.  Two arrays are considered equal if both
2646      * arrays contain the same number of elements, and all corresponding pairs
2647      * of elements in the two arrays are equal.  In other words, two arrays
2648      * are equal if they contain the same elements in the same order.  Also,
2649      * two array references are considered equal if both are {@code null}.
2650      *
2651      * @param a one array to be tested for equality
2652      * @param a2 the other array to be tested for equality
2653      * @return {@code true} if the two arrays are equal
2654      */
2655     @IntrinsicCandidate
2656     public static boolean equals(byte[] a, byte[] a2) {
2657         if (a==a2)
2658             return true;
2659         if (a==null || a2==null)
2660             return false;
2661 
2662         int length = a.length;
2663         if (a2.length != length)
2664             return false;
2665 
2666         return ArraysSupport.mismatch(a, a2, length) < 0;
2667     }
2668 
2669     /**
2670      * Returns true if the two specified arrays of bytes, over the specified
2671      * ranges, are <i>equal</i> to one another.
2672      *
2673      * <p>Two arrays are considered equal if the number of elements covered by
2674      * each range is the same, and all corresponding pairs of elements over the
2675      * specified ranges in the two arrays are equal.  In other words, two arrays
2676      * are equal if they contain, over the specified ranges, the same elements
2677      * in the same order.
2678      *
2679      * @param a the first array to be tested for equality
2680      * @param aFromIndex the index (inclusive) of the first element in the
2681      *                   first array to be tested
2682      * @param aToIndex the index (exclusive) of the last element in the
2683      *                 first array to be tested
2684      * @param b the second array to be tested for equality
2685      * @param bFromIndex the index (inclusive) of the first element in the
2686      *                   second array to be tested
2687      * @param bToIndex the index (exclusive) of the last element in the
2688      *                 second array to be tested
2689      * @return {@code true} if the two arrays, over the specified ranges, are
2690      *         equal
2691      * @throws IllegalArgumentException
2692      *         if {@code aFromIndex > aToIndex} or
2693      *         if {@code bFromIndex > bToIndex}
2694      * @throws ArrayIndexOutOfBoundsException
2695      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2696      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2697      * @throws NullPointerException
2698      *         if either array is {@code null}
2699      * @since 9
2700      */
2701     public static boolean equals(byte[] a, int aFromIndex, int aToIndex,
2702                                  byte[] b, int bFromIndex, int bToIndex) {
2703         rangeCheck(a.length, aFromIndex, aToIndex);
2704         rangeCheck(b.length, bFromIndex, bToIndex);
2705 
2706         int aLength = aToIndex - aFromIndex;
2707         int bLength = bToIndex - bFromIndex;
2708         if (aLength != bLength)
2709             return false;
2710 
2711         return ArraysSupport.mismatch(a, aFromIndex,
2712                                       b, bFromIndex,
2713                                       aLength) < 0;
2714     }
2715 
2716     /**
2717      * Returns {@code true} if the two specified arrays of booleans are
2718      * <i>equal</i> to one another.  Two arrays are considered equal if both
2719      * arrays contain the same number of elements, and all corresponding pairs
2720      * of elements in the two arrays are equal.  In other words, two arrays
2721      * are equal if they contain the same elements in the same order.  Also,
2722      * two array references are considered equal if both are {@code null}.
2723      *
2724      * @param a one array to be tested for equality
2725      * @param a2 the other array to be tested for equality
2726      * @return {@code true} if the two arrays are equal
2727      */
2728     public static boolean equals(boolean[] a, boolean[] a2) {
2729         if (a==a2)
2730             return true;
2731         if (a==null || a2==null)
2732             return false;
2733 
2734         int length = a.length;
2735         if (a2.length != length)
2736             return false;
2737 
2738         return ArraysSupport.mismatch(a, a2, length) < 0;
2739     }
2740 
2741     /**
2742      * Returns true if the two specified arrays of booleans, over the specified
2743      * ranges, are <i>equal</i> to one another.
2744      *
2745      * <p>Two arrays are considered equal if the number of elements covered by
2746      * each range is the same, and all corresponding pairs of elements over the
2747      * specified ranges in the two arrays are equal.  In other words, two arrays
2748      * are equal if they contain, over the specified ranges, the same elements
2749      * in the same order.
2750      *
2751      * @param a the first array to be tested for equality
2752      * @param aFromIndex the index (inclusive) of the first element in the
2753      *                   first array to be tested
2754      * @param aToIndex the index (exclusive) of the last element in the
2755      *                 first array to be tested
2756      * @param b the second array to be tested for equality
2757      * @param bFromIndex the index (inclusive) of the first element in the
2758      *                   second array to be tested
2759      * @param bToIndex the index (exclusive) of the last element in the
2760      *                 second array to be tested
2761      * @return {@code true} if the two arrays, over the specified ranges, are
2762      *         equal
2763      * @throws IllegalArgumentException
2764      *         if {@code aFromIndex > aToIndex} or
2765      *         if {@code bFromIndex > bToIndex}
2766      * @throws ArrayIndexOutOfBoundsException
2767      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2768      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2769      * @throws NullPointerException
2770      *         if either array is {@code null}
2771      * @since 9
2772      */
2773     public static boolean equals(boolean[] a, int aFromIndex, int aToIndex,
2774                                  boolean[] b, int bFromIndex, int bToIndex) {
2775         rangeCheck(a.length, aFromIndex, aToIndex);
2776         rangeCheck(b.length, bFromIndex, bToIndex);
2777 
2778         int aLength = aToIndex - aFromIndex;
2779         int bLength = bToIndex - bFromIndex;
2780         if (aLength != bLength)
2781             return false;
2782 
2783         return ArraysSupport.mismatch(a, aFromIndex,
2784                                       b, bFromIndex,
2785                                       aLength) < 0;
2786     }
2787 
2788     /**
2789      * Returns {@code true} if the two specified arrays of doubles are
2790      * <i>equal</i> to one another.  Two arrays are considered equal if both
2791      * arrays contain the same number of elements, and all corresponding pairs
2792      * of elements in the two arrays are equal.  In other words, two arrays
2793      * are equal if they contain the same elements in the same order.  Also,
2794      * two array references are considered equal if both are {@code null}.
2795      *
2796      * Two doubles {@code d1} and {@code d2} are considered equal if:
2797      * <pre>    {@code Double.valueOf(d1).equals(Double.valueOf(d2))}</pre>
2798      * (Unlike the {@code ==} operator, this method considers
2799      * {@code NaN} equal to itself, and 0.0d unequal to -0.0d.)
2800      *
2801      * @param a one array to be tested for equality
2802      * @param a2 the other array to be tested for equality
2803      * @return {@code true} if the two arrays are equal
2804      * @see Double#equals(Object)
2805      */
2806     public static boolean equals(double[] a, double[] a2) {
2807         if (a==a2)
2808             return true;
2809         if (a==null || a2==null)
2810             return false;
2811 
2812         int length = a.length;
2813         if (a2.length != length)
2814             return false;
2815 
2816         return ArraysSupport.mismatch(a, a2, length) < 0;
2817     }
2818 
2819     /**
2820      * Returns true if the two specified arrays of doubles, over the specified
2821      * ranges, are <i>equal</i> to one another.
2822      *
2823      * <p>Two arrays are considered equal if the number of elements covered by
2824      * each range is the same, and all corresponding pairs of elements over the
2825      * specified ranges in the two arrays are equal.  In other words, two arrays
2826      * are equal if they contain, over the specified ranges, the same elements
2827      * in the same order.
2828      *
2829      * <p>Two doubles {@code d1} and {@code d2} are considered equal if:
2830      * <pre>    {@code Double.valueOf(d1).equals(Double.valueOf(d2))}</pre>
2831      * (Unlike the {@code ==} operator, this method considers
2832      * {@code NaN} equal to itself, and 0.0d unequal to -0.0d.)
2833      *
2834      * @param a the first array to be tested for equality
2835      * @param aFromIndex the index (inclusive) of the first element in the
2836      *                   first array to be tested
2837      * @param aToIndex the index (exclusive) of the last element in the
2838      *                 first array to be tested
2839      * @param b the second array to be tested for equality
2840      * @param bFromIndex the index (inclusive) of the first element in the
2841      *                   second array to be tested
2842      * @param bToIndex the index (exclusive) of the last element in the
2843      *                 second array to be tested
2844      * @return {@code true} if the two arrays, over the specified ranges, are
2845      *         equal
2846      * @throws IllegalArgumentException
2847      *         if {@code aFromIndex > aToIndex} or
2848      *         if {@code bFromIndex > bToIndex}
2849      * @throws ArrayIndexOutOfBoundsException
2850      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2851      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2852      * @throws NullPointerException
2853      *         if either array is {@code null}
2854      * @see Double#equals(Object)
2855      * @since 9
2856      */
2857     public static boolean equals(double[] a, int aFromIndex, int aToIndex,
2858                                  double[] b, int bFromIndex, int bToIndex) {
2859         rangeCheck(a.length, aFromIndex, aToIndex);
2860         rangeCheck(b.length, bFromIndex, bToIndex);
2861 
2862         int aLength = aToIndex - aFromIndex;
2863         int bLength = bToIndex - bFromIndex;
2864         if (aLength != bLength)
2865             return false;
2866 
2867         return ArraysSupport.mismatch(a, aFromIndex,
2868                                       b, bFromIndex, aLength) < 0;
2869     }
2870 
2871     /**
2872      * Returns {@code true} if the two specified arrays of floats are
2873      * <i>equal</i> to one another.  Two arrays are considered equal if both
2874      * arrays contain the same number of elements, and all corresponding pairs
2875      * of elements in the two arrays are equal.  In other words, two arrays
2876      * are equal if they contain the same elements in the same order.  Also,
2877      * two array references are considered equal if both are {@code null}.
2878      *
2879      * Two floats {@code f1} and {@code f2} are considered equal if:
2880      * <pre>    {@code Float.valueOf(f1).equals(Float.valueOf(f2))}</pre>
2881      * (Unlike the {@code ==} operator, this method considers
2882      * {@code NaN} equal to itself, and 0.0f unequal to -0.0f.)
2883      *
2884      * @param a one array to be tested for equality
2885      * @param a2 the other array to be tested for equality
2886      * @return {@code true} if the two arrays are equal
2887      * @see Float#equals(Object)
2888      */
2889     public static boolean equals(float[] a, float[] a2) {
2890         if (a==a2)
2891             return true;
2892         if (a==null || a2==null)
2893             return false;
2894 
2895         int length = a.length;
2896         if (a2.length != length)
2897             return false;
2898 
2899         return ArraysSupport.mismatch(a, a2, length) < 0;
2900     }
2901 
2902     /**
2903      * Returns true if the two specified arrays of floats, over the specified
2904      * ranges, are <i>equal</i> to one another.
2905      *
2906      * <p>Two arrays are considered equal if the number of elements covered by
2907      * each range is the same, and all corresponding pairs of elements over the
2908      * specified ranges in the two arrays are equal.  In other words, two arrays
2909      * are equal if they contain, over the specified ranges, the same elements
2910      * in the same order.
2911      *
2912      * <p>Two floats {@code f1} and {@code f2} are considered equal if:
2913      * <pre>    {@code Float.valueOf(f1).equals(Float.valueOf(f2))}</pre>
2914      * (Unlike the {@code ==} operator, this method considers
2915      * {@code NaN} equal to itself, and 0.0f unequal to -0.0f.)
2916      *
2917      * @param a the first array to be tested for equality
2918      * @param aFromIndex the index (inclusive) of the first element in the
2919      *                   first array to be tested
2920      * @param aToIndex the index (exclusive) of the last element in the
2921      *                 first array to be tested
2922      * @param b the second array to be tested for equality
2923      * @param bFromIndex the index (inclusive) of the first element in the
2924      *                   second array to be tested
2925      * @param bToIndex the index (exclusive) of the last element in the
2926      *                 second array to be tested
2927      * @return {@code true} if the two arrays, over the specified ranges, are
2928      *         equal
2929      * @throws IllegalArgumentException
2930      *         if {@code aFromIndex > aToIndex} or
2931      *         if {@code bFromIndex > bToIndex}
2932      * @throws ArrayIndexOutOfBoundsException
2933      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
2934      *         if {@code bFromIndex < 0 or bToIndex > b.length}
2935      * @throws NullPointerException
2936      *         if either array is {@code null}
2937      * @see Float#equals(Object)
2938      * @since 9
2939      */
2940     public static boolean equals(float[] a, int aFromIndex, int aToIndex,
2941                                  float[] b, int bFromIndex, int bToIndex) {
2942         rangeCheck(a.length, aFromIndex, aToIndex);
2943         rangeCheck(b.length, bFromIndex, bToIndex);
2944 
2945         int aLength = aToIndex - aFromIndex;
2946         int bLength = bToIndex - bFromIndex;
2947         if (aLength != bLength)
2948             return false;
2949 
2950         return ArraysSupport.mismatch(a, aFromIndex,
2951                                       b, bFromIndex, aLength) < 0;
2952     }
2953 
2954     /**
2955      * Returns {@code true} if the two specified arrays of Objects are
2956      * <i>equal</i> to one another.  The two arrays are considered equal if
2957      * both arrays contain the same number of elements, and all corresponding
2958      * pairs of elements in the two arrays are equal.  Two objects {@code e1}
2959      * and {@code e2} are considered <i>equal</i> if
2960      * {@code Objects.equals(e1, e2)}.
2961      * In other words, the two arrays are equal if
2962      * they contain the same elements in the same order.  Also, two array
2963      * references are considered equal if both are {@code null}.
2964      *
2965      * @param a one array to be tested for equality
2966      * @param a2 the other array to be tested for equality
2967      * @return {@code true} if the two arrays are equal
2968      */
2969     public static boolean equals(Object[] a, Object[] a2) {
2970         if (a==a2)
2971             return true;
2972         if (a==null || a2==null)
2973             return false;
2974 
2975         int length = a.length;
2976         if (a2.length != length)
2977             return false;
2978 
2979         for (int i=0; i<length; i++) {
2980             if (!Objects.equals(a[i], a2[i]))
2981                 return false;
2982         }
2983 
2984         return true;
2985     }
2986 
2987     /**
2988      * Returns true if the two specified arrays of Objects, over the specified
2989      * ranges, are <i>equal</i> to one another.
2990      *
2991      * <p>Two arrays are considered equal if the number of elements covered by
2992      * each range is the same, and all corresponding pairs of elements over the
2993      * specified ranges in the two arrays are equal.  In other words, two arrays
2994      * are equal if they contain, over the specified ranges, the same elements
2995      * in the same order.
2996      *
2997      * <p>Two objects {@code e1} and {@code e2} are considered <i>equal</i> if
2998      * {@code Objects.equals(e1, e2)}.
2999      *
3000      * @param a the first array to be tested for equality
3001      * @param aFromIndex the index (inclusive) of the first element in the
3002      *                   first array to be tested
3003      * @param aToIndex the index (exclusive) of the last element in the
3004      *                 first array to be tested
3005      * @param b the second array to be tested for equality
3006      * @param bFromIndex the index (inclusive) of the first element in the
3007      *                   second array to be tested
3008      * @param bToIndex the index (exclusive) of the last element in the
3009      *                 second array to be tested
3010      * @return {@code true} if the two arrays, over the specified ranges, are
3011      *         equal
3012      * @throws IllegalArgumentException
3013      *         if {@code aFromIndex > aToIndex} or
3014      *         if {@code bFromIndex > bToIndex}
3015      * @throws ArrayIndexOutOfBoundsException
3016      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
3017      *         if {@code bFromIndex < 0 or bToIndex > b.length}
3018      * @throws NullPointerException
3019      *         if either array is {@code null}
3020      * @since 9
3021      */
3022     public static boolean equals(Object[] a, int aFromIndex, int aToIndex,
3023                                  Object[] b, int bFromIndex, int bToIndex) {
3024         rangeCheck(a.length, aFromIndex, aToIndex);
3025         rangeCheck(b.length, bFromIndex, bToIndex);
3026 
3027         int aLength = aToIndex - aFromIndex;
3028         int bLength = bToIndex - bFromIndex;
3029         if (aLength != bLength)
3030             return false;
3031 
3032         for (int i = 0; i < aLength; i++) {
3033             if (!Objects.equals(a[aFromIndex++], b[bFromIndex++]))
3034                 return false;
3035         }
3036 
3037         return true;
3038     }
3039 
3040     /**
3041      * Returns {@code true} if the two specified arrays of Objects are
3042      * <i>equal</i> to one another.
3043      *
3044      * <p>Two arrays are considered equal if both arrays contain the same number
3045      * of elements, and all corresponding pairs of elements in the two arrays
3046      * are equal.  In other words, the two arrays are equal if they contain the
3047      * same elements in the same order.  Also, two array references are
3048      * considered equal if both are {@code null}.
3049      *
3050      * <p>Two objects {@code e1} and {@code e2} are considered <i>equal</i> if,
3051      * given the specified comparator, {@code cmp.compare(e1, e2) == 0}.
3052      *
3053      * @param a one array to be tested for equality
3054      * @param a2 the other array to be tested for equality
3055      * @param cmp the comparator to compare array elements
3056      * @param <T> the type of array elements
3057      * @return {@code true} if the two arrays are equal
3058      * @throws NullPointerException if the comparator is {@code null}
3059      * @since 9
3060      */
3061     public static <T> boolean equals(T[] a, T[] a2, Comparator<? super T> cmp) {
3062         Objects.requireNonNull(cmp);
3063         if (a==a2)
3064             return true;
3065         if (a==null || a2==null)
3066             return false;
3067 
3068         int length = a.length;
3069         if (a2.length != length)
3070             return false;
3071 
3072         for (int i=0; i<length; i++) {
3073             if (cmp.compare(a[i], a2[i]) != 0)
3074                 return false;
3075         }
3076 
3077         return true;
3078     }
3079 
3080     /**
3081      * Returns true if the two specified arrays of Objects, over the specified
3082      * ranges, are <i>equal</i> to one another.
3083      *
3084      * <p>Two arrays are considered equal if the number of elements covered by
3085      * each range is the same, and all corresponding pairs of elements over the
3086      * specified ranges in the two arrays are equal.  In other words, two arrays
3087      * are equal if they contain, over the specified ranges, the same elements
3088      * in the same order.
3089      *
3090      * <p>Two objects {@code e1} and {@code e2} are considered <i>equal</i> if,
3091      * given the specified comparator, {@code cmp.compare(e1, e2) == 0}.
3092      *
3093      * @param a the first array to be tested for equality
3094      * @param aFromIndex the index (inclusive) of the first element in the
3095      *                   first array to be tested
3096      * @param aToIndex the index (exclusive) of the last element in the
3097      *                 first array to be tested
3098      * @param b the second array to be tested for equality
3099      * @param bFromIndex the index (inclusive) of the first element in the
3100      *                   second array to be tested
3101      * @param bToIndex the index (exclusive) of the last element in the
3102      *                 second array to be tested
3103      * @param cmp the comparator to compare array elements
3104      * @param <T> the type of array elements
3105      * @return {@code true} if the two arrays, over the specified ranges, are
3106      *         equal
3107      * @throws IllegalArgumentException
3108      *         if {@code aFromIndex > aToIndex} or
3109      *         if {@code bFromIndex > bToIndex}
3110      * @throws ArrayIndexOutOfBoundsException
3111      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
3112      *         if {@code bFromIndex < 0 or bToIndex > b.length}
3113      * @throws NullPointerException
3114      *         if either array or the comparator is {@code null}
3115      * @since 9
3116      */
3117     public static <T> boolean equals(T[] a, int aFromIndex, int aToIndex,
3118                                      T[] b, int bFromIndex, int bToIndex,
3119                                      Comparator<? super T> cmp) {
3120         Objects.requireNonNull(cmp);
3121         rangeCheck(a.length, aFromIndex, aToIndex);
3122         rangeCheck(b.length, bFromIndex, bToIndex);
3123 
3124         int aLength = aToIndex - aFromIndex;
3125         int bLength = bToIndex - bFromIndex;
3126         if (aLength != bLength)
3127             return false;
3128 
3129         for (int i = 0; i < aLength; i++) {
3130             if (cmp.compare(a[aFromIndex++], b[bFromIndex++]) != 0)
3131                 return false;
3132         }
3133 
3134         return true;
3135     }
3136 
3137     // Filling
3138 
3139     /**
3140      * Assigns the specified long value to each element of the specified array
3141      * of longs.
3142      *
3143      * @param a the array to be filled
3144      * @param val the value to be stored in all elements of the array
3145      */
3146     public static void fill(long[] a, long val) {
3147         for (int i = 0, len = a.length; i < len; i++)
3148             a[i] = val;
3149     }
3150 
3151     /**
3152      * Assigns the specified long value to each element of the specified
3153      * range of the specified array of longs.  The range to be filled
3154      * extends from index {@code fromIndex}, inclusive, to index
3155      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3156      * range to be filled is empty.)
3157      *
3158      * @param a the array to be filled
3159      * @param fromIndex the index of the first element (inclusive) to be
3160      *        filled with the specified value
3161      * @param toIndex the index of the last element (exclusive) to be
3162      *        filled with the specified value
3163      * @param val the value to be stored in all elements of the array
3164      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3165      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3166      *         {@code toIndex > a.length}
3167      */
3168     public static void fill(long[] a, int fromIndex, int toIndex, long val) {
3169         rangeCheck(a.length, fromIndex, toIndex);
3170         for (int i = fromIndex; i < toIndex; i++)
3171             a[i] = val;
3172     }
3173 
3174     /**
3175      * Assigns the specified int value to each element of the specified array
3176      * of ints.
3177      *
3178      * @param a the array to be filled
3179      * @param val the value to be stored in all elements of the array
3180      */
3181     public static void fill(int[] a, int val) {
3182         for (int i = 0, len = a.length; i < len; i++)
3183             a[i] = val;
3184     }
3185 
3186     /**
3187      * Assigns the specified int value to each element of the specified
3188      * range of the specified array of ints.  The range to be filled
3189      * extends from index {@code fromIndex}, inclusive, to index
3190      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3191      * range to be filled is empty.)
3192      *
3193      * @param a the array to be filled
3194      * @param fromIndex the index of the first element (inclusive) to be
3195      *        filled with the specified value
3196      * @param toIndex the index of the last element (exclusive) to be
3197      *        filled with the specified value
3198      * @param val the value to be stored in all elements of the array
3199      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3200      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3201      *         {@code toIndex > a.length}
3202      */
3203     public static void fill(int[] a, int fromIndex, int toIndex, int val) {
3204         rangeCheck(a.length, fromIndex, toIndex);
3205         for (int i = fromIndex; i < toIndex; i++)
3206             a[i] = val;
3207     }
3208 
3209     /**
3210      * Assigns the specified short value to each element of the specified array
3211      * of shorts.
3212      *
3213      * @param a the array to be filled
3214      * @param val the value to be stored in all elements of the array
3215      */
3216     public static void fill(short[] a, short val) {
3217         for (int i = 0, len = a.length; i < len; i++)
3218             a[i] = val;
3219     }
3220 
3221     /**
3222      * Assigns the specified short value to each element of the specified
3223      * range of the specified array of shorts.  The range to be filled
3224      * extends from index {@code fromIndex}, inclusive, to index
3225      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3226      * range to be filled is empty.)
3227      *
3228      * @param a the array to be filled
3229      * @param fromIndex the index of the first element (inclusive) to be
3230      *        filled with the specified value
3231      * @param toIndex the index of the last element (exclusive) to be
3232      *        filled with the specified value
3233      * @param val the value to be stored in all elements of the array
3234      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3235      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3236      *         {@code toIndex > a.length}
3237      */
3238     public static void fill(short[] a, int fromIndex, int toIndex, short val) {
3239         rangeCheck(a.length, fromIndex, toIndex);
3240         for (int i = fromIndex; i < toIndex; i++)
3241             a[i] = val;
3242     }
3243 
3244     /**
3245      * Assigns the specified char value to each element of the specified array
3246      * of chars.
3247      *
3248      * @param a the array to be filled
3249      * @param val the value to be stored in all elements of the array
3250      */
3251     public static void fill(char[] a, char val) {
3252         for (int i = 0, len = a.length; i < len; i++)
3253             a[i] = val;
3254     }
3255 
3256     /**
3257      * Assigns the specified char value to each element of the specified
3258      * range of the specified array of chars.  The range to be filled
3259      * extends from index {@code fromIndex}, inclusive, to index
3260      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3261      * range to be filled is empty.)
3262      *
3263      * @param a the array to be filled
3264      * @param fromIndex the index of the first element (inclusive) to be
3265      *        filled with the specified value
3266      * @param toIndex the index of the last element (exclusive) to be
3267      *        filled with the specified value
3268      * @param val the value to be stored in all elements of the array
3269      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3270      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3271      *         {@code toIndex > a.length}
3272      */
3273     public static void fill(char[] a, int fromIndex, int toIndex, char val) {
3274         rangeCheck(a.length, fromIndex, toIndex);
3275         for (int i = fromIndex; i < toIndex; i++)
3276             a[i] = val;
3277     }
3278 
3279     /**
3280      * Assigns the specified byte value to each element of the specified array
3281      * of bytes.
3282      *
3283      * @param a the array to be filled
3284      * @param val the value to be stored in all elements of the array
3285      */
3286     public static void fill(byte[] a, byte val) {
3287         for (int i = 0, len = a.length; i < len; i++)
3288             a[i] = val;
3289     }
3290 
3291     /**
3292      * Assigns the specified byte value to each element of the specified
3293      * range of the specified array of bytes.  The range to be filled
3294      * extends from index {@code fromIndex}, inclusive, to index
3295      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3296      * range to be filled is empty.)
3297      *
3298      * @param a the array to be filled
3299      * @param fromIndex the index of the first element (inclusive) to be
3300      *        filled with the specified value
3301      * @param toIndex the index of the last element (exclusive) to be
3302      *        filled with the specified value
3303      * @param val the value to be stored in all elements of the array
3304      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3305      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3306      *         {@code toIndex > a.length}
3307      */
3308     public static void fill(byte[] a, int fromIndex, int toIndex, byte val) {
3309         rangeCheck(a.length, fromIndex, toIndex);
3310         for (int i = fromIndex; i < toIndex; i++)
3311             a[i] = val;
3312     }
3313 
3314     /**
3315      * Assigns the specified boolean value to each element of the specified
3316      * array of booleans.
3317      *
3318      * @param a the array to be filled
3319      * @param val the value to be stored in all elements of the array
3320      */
3321     public static void fill(boolean[] a, boolean val) {
3322         for (int i = 0, len = a.length; i < len; i++)
3323             a[i] = val;
3324     }
3325 
3326     /**
3327      * Assigns the specified boolean value to each element of the specified
3328      * range of the specified array of booleans.  The range to be filled
3329      * extends from index {@code fromIndex}, inclusive, to index
3330      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3331      * range to be filled is empty.)
3332      *
3333      * @param a the array to be filled
3334      * @param fromIndex the index of the first element (inclusive) to be
3335      *        filled with the specified value
3336      * @param toIndex the index of the last element (exclusive) to be
3337      *        filled with the specified value
3338      * @param val the value to be stored in all elements of the array
3339      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3340      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3341      *         {@code toIndex > a.length}
3342      */
3343     public static void fill(boolean[] a, int fromIndex, int toIndex,
3344                             boolean val) {
3345         rangeCheck(a.length, fromIndex, toIndex);
3346         for (int i = fromIndex; i < toIndex; i++)
3347             a[i] = val;
3348     }
3349 
3350     /**
3351      * Assigns the specified double value to each element of the specified
3352      * array of doubles.
3353      *
3354      * @param a the array to be filled
3355      * @param val the value to be stored in all elements of the array
3356      */
3357     public static void fill(double[] a, double val) {
3358         for (int i = 0, len = a.length; i < len; i++)
3359             a[i] = val;
3360     }
3361 
3362     /**
3363      * Assigns the specified double value to each element of the specified
3364      * range of the specified array of doubles.  The range to be filled
3365      * extends from index {@code fromIndex}, inclusive, to index
3366      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3367      * range to be filled is empty.)
3368      *
3369      * @param a the array to be filled
3370      * @param fromIndex the index of the first element (inclusive) to be
3371      *        filled with the specified value
3372      * @param toIndex the index of the last element (exclusive) to be
3373      *        filled with the specified value
3374      * @param val the value to be stored in all elements of the array
3375      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3376      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3377      *         {@code toIndex > a.length}
3378      */
3379     public static void fill(double[] a, int fromIndex, int toIndex,double val){
3380         rangeCheck(a.length, fromIndex, toIndex);
3381         for (int i = fromIndex; i < toIndex; i++)
3382             a[i] = val;
3383     }
3384 
3385     /**
3386      * Assigns the specified float value to each element of the specified array
3387      * of floats.
3388      *
3389      * @param a the array to be filled
3390      * @param val the value to be stored in all elements of the array
3391      */
3392     public static void fill(float[] a, float val) {
3393         for (int i = 0, len = a.length; i < len; i++)
3394             a[i] = val;
3395     }
3396 
3397     /**
3398      * Assigns the specified float value to each element of the specified
3399      * range of the specified array of floats.  The range to be filled
3400      * extends from index {@code fromIndex}, inclusive, to index
3401      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3402      * range to be filled is empty.)
3403      *
3404      * @param a the array to be filled
3405      * @param fromIndex the index of the first element (inclusive) to be
3406      *        filled with the specified value
3407      * @param toIndex the index of the last element (exclusive) to be
3408      *        filled with the specified value
3409      * @param val the value to be stored in all elements of the array
3410      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3411      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3412      *         {@code toIndex > a.length}
3413      */
3414     public static void fill(float[] a, int fromIndex, int toIndex, float val) {
3415         rangeCheck(a.length, fromIndex, toIndex);
3416         for (int i = fromIndex; i < toIndex; i++)
3417             a[i] = val;
3418     }
3419 
3420     /**
3421      * Assigns the specified Object reference to each element of the specified
3422      * array of Objects.
3423      *
3424      * @param a the array to be filled
3425      * @param val the value to be stored in all elements of the array
3426      * @throws ArrayStoreException if the specified value is not of a
3427      *         runtime type that can be stored in the specified array
3428      */
3429     public static void fill(Object[] a, Object val) {
3430         for (int i = 0, len = a.length; i < len; i++)
3431             a[i] = val;
3432     }
3433 
3434     /**
3435      * Assigns the specified Object reference to each element of the specified
3436      * range of the specified array of Objects.  The range to be filled
3437      * extends from index {@code fromIndex}, inclusive, to index
3438      * {@code toIndex}, exclusive.  (If {@code fromIndex==toIndex}, the
3439      * range to be filled is empty.)
3440      *
3441      * @param a the array to be filled
3442      * @param fromIndex the index of the first element (inclusive) to be
3443      *        filled with the specified value
3444      * @param toIndex the index of the last element (exclusive) to be
3445      *        filled with the specified value
3446      * @param val the value to be stored in all elements of the array
3447      * @throws IllegalArgumentException if {@code fromIndex > toIndex}
3448      * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or
3449      *         {@code toIndex > a.length}
3450      * @throws ArrayStoreException if the specified value is not of a
3451      *         runtime type that can be stored in the specified array
3452      */
3453     public static void fill(Object[] a, int fromIndex, int toIndex, Object val) {
3454         rangeCheck(a.length, fromIndex, toIndex);
3455         for (int i = fromIndex; i < toIndex; i++)
3456             a[i] = val;
3457     }
3458 
3459     // Cloning
3460 
3461     /**
3462      * Copies the specified array, truncating or padding with nulls (if necessary)
3463      * so the copy has the specified length.  For all indices that are
3464      * valid in both the original array and the copy, the two arrays will
3465      * contain identical values.  For any indices that are valid in the
3466      * copy but not the original, the copy will contain {@code null}.
3467      * Such indices will exist if and only if the specified length
3468      * is greater than that of the original array.
3469      * The resulting array is of exactly the same class as the original array.
3470      *
3471      * @param <T> the class of the objects in the array
3472      * @param original the array to be copied
3473      * @param newLength the length of the copy to be returned
3474      * @return a copy of the original array, truncated or padded with nulls
3475      *     to obtain the specified length
3476      * @throws NegativeArraySizeException if {@code newLength} is negative
3477      * @throws NullPointerException if {@code original} is null
3478      * @since 1.6
3479      */
3480     @SuppressWarnings("unchecked")
3481     public static <T> T[] copyOf(T[] original, int newLength) {
3482         return (T[]) copyOf(original, newLength, original.getClass());
3483     }
3484 
3485     /**
3486      * Copies the specified array, truncating or padding with nulls (if necessary)
3487      * so the copy has the specified length.  For all indices that are
3488      * valid in both the original array and the copy, the two arrays will
3489      * contain identical values.  For any indices that are valid in the
3490      * copy but not the original, the copy will contain {@code null}.
3491      * Such indices will exist if and only if the specified length
3492      * is greater than that of the original array.
3493      * The resulting array is of the class {@code newType}.
3494      *
3495      * @param <T> the class of the objects in the returned array
3496      * @param <U> the class of the objects in the original array
3497      * @param original the array to be copied
3498      * @param newLength the length of the copy to be returned
3499      * @param newType the class of the copy to be returned
3500      * @return a copy of the original array, truncated or padded with nulls
3501      *     to obtain the specified length
3502      * @throws NegativeArraySizeException if {@code newLength} is negative
3503      * @throws NullPointerException if {@code original} is null
3504      * @throws ArrayStoreException if an element copied from
3505      *     {@code original} is not of a runtime type that can be stored in
3506      *     an array of class {@code newType}
3507      * @since 1.6
3508      */
3509     @IntrinsicCandidate
3510     public static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType) {
3511         Class<?> componentType = newType.getComponentType();
3512         @SuppressWarnings("unchecked")
3513         T[] copy = ((Object)newType == (Object)Object[].class)
3514             ? (T[]) new Object[newLength]
3515             : (original.getClass() == newType && componentType.isValue() && ValueClass.isNullRestrictedArray(original)
3516                     ? (T[]) ValueClass.newNullRestrictedArray(newType.getComponentType(), newLength)
3517                     : (T[]) Array.newInstance(componentType, newLength));
3518         System.arraycopy(original, 0, copy, 0,
3519                          Math.min(original.length, newLength));
3520         return copy;
3521     }
3522 
3523     /**
3524      * Copies the specified array, truncating or padding with zeros (if necessary)
3525      * so the copy has the specified length.  For all indices that are
3526      * valid in both the original array and the copy, the two arrays will
3527      * contain identical values.  For any indices that are valid in the
3528      * copy but not the original, the copy will contain {@code (byte)0}.
3529      * Such indices will exist if and only if the specified length
3530      * is greater than that of the original array.
3531      *
3532      * @param original the array to be copied
3533      * @param newLength the length of the copy to be returned
3534      * @return a copy of the original array, truncated or padded with zeros
3535      *     to obtain the specified length
3536      * @throws NegativeArraySizeException if {@code newLength} is negative
3537      * @throws NullPointerException if {@code original} is null
3538      * @since 1.6
3539      */
3540     public static byte[] copyOf(byte[] original, int newLength) {
3541         if (newLength == original.length) {
3542             return original.clone();
3543         }
3544         byte[] copy = new byte[newLength];
3545         System.arraycopy(original, 0, copy, 0,
3546                          Math.min(original.length, newLength));
3547         return copy;
3548     }
3549 
3550     /**
3551      * Copies the specified array, truncating or padding with zeros (if necessary)
3552      * so the copy has the specified length.  For all indices that are
3553      * valid in both the original array and the copy, the two arrays will
3554      * contain identical values.  For any indices that are valid in the
3555      * copy but not the original, the copy will contain {@code (short)0}.
3556      * Such indices will exist if and only if the specified length
3557      * is greater than that of the original array.
3558      *
3559      * @param original the array to be copied
3560      * @param newLength the length of the copy to be returned
3561      * @return a copy of the original array, truncated or padded with zeros
3562      *     to obtain the specified length
3563      * @throws NegativeArraySizeException if {@code newLength} is negative
3564      * @throws NullPointerException if {@code original} is null
3565      * @since 1.6
3566      */
3567     public static short[] copyOf(short[] original, int newLength) {
3568         if (newLength == original.length) {
3569             return original.clone();
3570         }
3571         short[] copy = new short[newLength];
3572         System.arraycopy(original, 0, copy, 0,
3573                          Math.min(original.length, newLength));
3574         return copy;
3575     }
3576 
3577     /**
3578      * Copies the specified array, truncating or padding with zeros (if necessary)
3579      * so the copy has the specified length.  For all indices that are
3580      * valid in both the original array and the copy, the two arrays will
3581      * contain identical values.  For any indices that are valid in the
3582      * copy but not the original, the copy will contain {@code 0}.
3583      * Such indices will exist if and only if the specified length
3584      * is greater than that of the original array.
3585      *
3586      * @param original the array to be copied
3587      * @param newLength the length of the copy to be returned
3588      * @return a copy of the original array, truncated or padded with zeros
3589      *     to obtain the specified length
3590      * @throws NegativeArraySizeException if {@code newLength} is negative
3591      * @throws NullPointerException if {@code original} is null
3592      * @since 1.6
3593      */
3594     public static int[] copyOf(int[] original, int newLength) {
3595         if (newLength == original.length) {
3596             return original.clone();
3597         }
3598         int[] copy = new int[newLength];
3599         System.arraycopy(original, 0, copy, 0,
3600                          Math.min(original.length, newLength));
3601         return copy;
3602     }
3603 
3604 
3605     /**
3606      * Copies the specified array, truncating or padding with zeros (if necessary)
3607      * so the copy has the specified length.  For all indices that are
3608      * valid in both the original array and the copy, the two arrays will
3609      * contain identical values.  For any indices that are valid in the
3610      * copy but not the original, the copy will contain {@code 0L}.
3611      * Such indices will exist if and only if the specified length
3612      * is greater than that of the original array.
3613      *
3614      * @param original the array to be copied
3615      * @param newLength the length of the copy to be returned
3616      * @return a copy of the original array, truncated or padded with zeros
3617      *     to obtain the specified length
3618      * @throws NegativeArraySizeException if {@code newLength} is negative
3619      * @throws NullPointerException if {@code original} is null
3620      * @since 1.6
3621      */
3622     public static long[] copyOf(long[] original, int newLength) {
3623         if (newLength == original.length) {
3624             return original.clone();
3625         }
3626         long[] copy = new long[newLength];
3627         System.arraycopy(original, 0, copy, 0,
3628                          Math.min(original.length, newLength));
3629         return copy;
3630     }
3631 
3632     /**
3633      * Copies the specified array, truncating or padding with null characters (if necessary)
3634      * so the copy has the specified length.  For all indices that are valid
3635      * in both the original array and the copy, the two arrays will contain
3636      * identical values.  For any indices that are valid in the copy but not
3637      * the original, the copy will contain {@code '\u005cu0000'}.  Such indices
3638      * will exist if and only if the specified length is greater than that of
3639      * the original array.
3640      *
3641      * @param original the array to be copied
3642      * @param newLength the length of the copy to be returned
3643      * @return a copy of the original array, truncated or padded with null characters
3644      *     to obtain the specified length
3645      * @throws NegativeArraySizeException if {@code newLength} is negative
3646      * @throws NullPointerException if {@code original} is null
3647      * @since 1.6
3648      */
3649     public static char[] copyOf(char[] original, int newLength) {
3650         if (newLength == original.length) {
3651             return original.clone();
3652         }
3653         char[] copy = new char[newLength];
3654         System.arraycopy(original, 0, copy, 0,
3655                          Math.min(original.length, newLength));
3656         return copy;
3657     }
3658 
3659     /**
3660      * Copies the specified array, truncating or padding with zeros (if necessary)
3661      * so the copy has the specified length.  For all indices that are
3662      * valid in both the original array and the copy, the two arrays will
3663      * contain identical values.  For any indices that are valid in the
3664      * copy but not the original, the copy will contain {@code 0f}.
3665      * Such indices will exist if and only if the specified length
3666      * is greater than that of the original array.
3667      *
3668      * @param original the array to be copied
3669      * @param newLength the length of the copy to be returned
3670      * @return a copy of the original array, truncated or padded with zeros
3671      *     to obtain the specified length
3672      * @throws NegativeArraySizeException if {@code newLength} is negative
3673      * @throws NullPointerException if {@code original} is null
3674      * @since 1.6
3675      */
3676     public static float[] copyOf(float[] original, int newLength) {
3677         if (newLength == original.length) {
3678             return original.clone();
3679         }
3680         float[] copy = new float[newLength];
3681         System.arraycopy(original, 0, copy, 0,
3682                          Math.min(original.length, newLength));
3683         return copy;
3684     }
3685 
3686     /**
3687      * Copies the specified array, truncating or padding with zeros (if necessary)
3688      * so the copy has the specified length.  For all indices that are
3689      * valid in both the original array and the copy, the two arrays will
3690      * contain identical values.  For any indices that are valid in the
3691      * copy but not the original, the copy will contain {@code 0d}.
3692      * Such indices will exist if and only if the specified length
3693      * is greater than that of the original array.
3694      *
3695      * @param original the array to be copied
3696      * @param newLength the length of the copy to be returned
3697      * @return a copy of the original array, truncated or padded with zeros
3698      *     to obtain the specified length
3699      * @throws NegativeArraySizeException if {@code newLength} is negative
3700      * @throws NullPointerException if {@code original} is null
3701      * @since 1.6
3702      */
3703     public static double[] copyOf(double[] original, int newLength) {
3704         if (newLength == original.length) {
3705             return original.clone();
3706         }
3707         double[] copy = new double[newLength];
3708         System.arraycopy(original, 0, copy, 0,
3709                          Math.min(original.length, newLength));
3710         return copy;
3711     }
3712 
3713     /**
3714      * Copies the specified array, truncating or padding with {@code false} (if necessary)
3715      * so the copy has the specified length.  For all indices that are
3716      * valid in both the original array and the copy, the two arrays will
3717      * contain identical values.  For any indices that are valid in the
3718      * copy but not the original, the copy will contain {@code false}.
3719      * Such indices will exist if and only if the specified length
3720      * is greater than that of the original array.
3721      *
3722      * @param original the array to be copied
3723      * @param newLength the length of the copy to be returned
3724      * @return a copy of the original array, truncated or padded with false elements
3725      *     to obtain the specified length
3726      * @throws NegativeArraySizeException if {@code newLength} is negative
3727      * @throws NullPointerException if {@code original} is null
3728      * @since 1.6
3729      */
3730     public static boolean[] copyOf(boolean[] original, int newLength) {
3731         if (newLength == original.length) {
3732             return original.clone();
3733         }
3734         boolean[] copy = new boolean[newLength];
3735         System.arraycopy(original, 0, copy, 0,
3736                          Math.min(original.length, newLength));
3737         return copy;
3738     }
3739 
3740     /**
3741      * Copies the specified range of the specified array into a new array.
3742      * The initial index of the range ({@code from}) must lie between zero
3743      * and {@code original.length}, inclusive.  The value at
3744      * {@code original[from]} is placed into the initial element of the copy
3745      * (unless {@code from == original.length} or {@code from == to}).
3746      * Values from subsequent elements in the original array are placed into
3747      * subsequent elements in the copy.  The final index of the range
3748      * ({@code to}), which must be greater than or equal to {@code from},
3749      * may be greater than {@code original.length}, in which case
3750      * {@code null} is placed in all elements of the copy whose index is
3751      * greater than or equal to {@code original.length - from}.  The length
3752      * of the returned array will be {@code to - from}.
3753      * <p>
3754      * The resulting array is of exactly the same class as the original array.
3755      *
3756      * @param <T> the class of the objects in the array
3757      * @param original the array from which a range is to be copied
3758      * @param from the initial index of the range to be copied, inclusive
3759      * @param to the final index of the range to be copied, exclusive.
3760      *     (This index may lie outside the array.)
3761      * @return a new array containing the specified range from the original array,
3762      *     truncated or padded with nulls to obtain the required length
3763      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
3764      *     or {@code from > original.length}
3765      * @throws IllegalArgumentException if {@code from > to}
3766      * @throws NullPointerException if {@code original} is null
3767      * @since 1.6
3768      */
3769     @SuppressWarnings("unchecked")
3770     public static <T> T[] copyOfRange(T[] original, int from, int to) {
3771         return copyOfRange(original, from, to, (Class<? extends T[]>) original.getClass());
3772     }
3773 
3774     /**
3775      * Copies the specified range of the specified array into a new array.
3776      * The initial index of the range ({@code from}) must lie between zero
3777      * and {@code original.length}, inclusive.  The value at
3778      * {@code original[from]} is placed into the initial element of the copy
3779      * (unless {@code from == original.length} or {@code from == to}).
3780      * Values from subsequent elements in the original array are placed into
3781      * subsequent elements in the copy.  The final index of the range
3782      * ({@code to}), which must be greater than or equal to {@code from},
3783      * may be greater than {@code original.length}, in which case
3784      * {@code null} is placed in all elements of the copy whose index is
3785      * greater than or equal to {@code original.length - from}.  The length
3786      * of the returned array will be {@code to - from}.
3787      * The resulting array is of the class {@code newType}.
3788      *
3789      * @param <T> the class of the objects in the returned array
3790      * @param <U> the class of the objects in the original array
3791      * @param original the array from which a range is to be copied
3792      * @param from the initial index of the range to be copied, inclusive
3793      * @param to the final index of the range to be copied, exclusive.
3794      *     (This index may lie outside the array.)
3795      * @param newType the class of the copy to be returned
3796      * @return a new array containing the specified range from the original array,
3797      *     truncated or padded with nulls to obtain the required length
3798      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
3799      *     or {@code from > original.length}
3800      * @throws IllegalArgumentException if {@code from > to}
3801      * @throws NullPointerException if {@code original} is null
3802      * @throws ArrayStoreException if an element copied from
3803      *     {@code original} is not of a runtime type that can be stored in
3804      *     an array of class {@code newType}.
3805      * @since 1.6
3806      */
3807     @IntrinsicCandidate
3808     public static <T,U> T[] copyOfRange(U[] original, int from, int to, Class<? extends T[]> newType) {
3809         int newLength = to - from;
3810         if (newLength < 0) {
3811             throw new IllegalArgumentException(from + " > " + to);
3812         }
3813         Class<?> componentType = newType.getComponentType();
3814         @SuppressWarnings("unchecked")
3815         T[] copy = ((Object)newType == (Object)Object[].class)
3816             ? (T[]) new Object[newLength]
3817             : (original.getClass() == newType && componentType.isValue() && ValueClass.isNullRestrictedArray(original)
3818                     ? (T[]) ValueClass.newNullRestrictedArray(componentType, newLength)
3819                     : (T[]) Array.newInstance(componentType, newLength));
3820         System.arraycopy(original, from, copy, 0,
3821                          Math.min(original.length - from, newLength));
3822         return copy;
3823     }
3824 
3825     /**
3826      * Copies the specified range of the specified array into a new array.
3827      * The initial index of the range ({@code from}) must lie between zero
3828      * and {@code original.length}, inclusive.  The value at
3829      * {@code original[from]} is placed into the initial element of the copy
3830      * (unless {@code from == original.length} or {@code from == to}).
3831      * Values from subsequent elements in the original array are placed into
3832      * subsequent elements in the copy.  The final index of the range
3833      * ({@code to}), which must be greater than or equal to {@code from},
3834      * may be greater than {@code original.length}, in which case
3835      * {@code (byte)0} is placed in all elements of the copy whose index is
3836      * greater than or equal to {@code original.length - from}.  The length
3837      * of the returned array will be {@code to - from}.
3838      *
3839      * @param original the array from which a range is to be copied
3840      * @param from the initial index of the range to be copied, inclusive
3841      * @param to the final index of the range to be copied, exclusive.
3842      *     (This index may lie outside the array.)
3843      * @return a new array containing the specified range from the original array,
3844      *     truncated or padded with zeros to obtain the required length
3845      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
3846      *     or {@code from > original.length}
3847      * @throws IllegalArgumentException if {@code from > to}
3848      * @throws NullPointerException if {@code original} is null
3849      * @since 1.6
3850      */
3851     public static byte[] copyOfRange(byte[] original, int from, int to) {
3852         if (from == 0 && to == original.length) {
3853             return original.clone();
3854         }
3855         int newLength = to - from;
3856         if (newLength < 0) {
3857             throw new IllegalArgumentException(from + " > " + to);
3858         }
3859         byte[] copy = new byte[newLength];
3860         System.arraycopy(original, from, copy, 0,
3861                 Math.min(original.length - from, newLength));
3862         return copy;
3863     }
3864 
3865     /**
3866      * Copies the specified range of the specified array into a new array.
3867      * The initial index of the range ({@code from}) must lie between zero
3868      * and {@code original.length}, inclusive.  The value at
3869      * {@code original[from]} is placed into the initial element of the copy
3870      * (unless {@code from == original.length} or {@code from == to}).
3871      * Values from subsequent elements in the original array are placed into
3872      * subsequent elements in the copy.  The final index of the range
3873      * ({@code to}), which must be greater than or equal to {@code from},
3874      * may be greater than {@code original.length}, in which case
3875      * {@code (short)0} is placed in all elements of the copy whose index is
3876      * greater than or equal to {@code original.length - from}.  The length
3877      * of the returned array will be {@code to - from}.
3878      *
3879      * @param original the array from which a range is to be copied
3880      * @param from the initial index of the range to be copied, inclusive
3881      * @param to the final index of the range to be copied, exclusive.
3882      *     (This index may lie outside the array.)
3883      * @return a new array containing the specified range from the original array,
3884      *     truncated or padded with zeros to obtain the required length
3885      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
3886      *     or {@code from > original.length}
3887      * @throws IllegalArgumentException if {@code from > to}
3888      * @throws NullPointerException if {@code original} is null
3889      * @since 1.6
3890      */
3891     public static short[] copyOfRange(short[] original, int from, int to) {
3892         if (from == 0 && to == original.length) {
3893             return original.clone();
3894         }
3895         int newLength = to - from;
3896         if (newLength < 0) {
3897             throw new IllegalArgumentException(from + " > " + to);
3898         }
3899         short[] copy = new short[newLength];
3900         System.arraycopy(original, from, copy, 0,
3901                          Math.min(original.length - from, newLength));
3902         return copy;
3903     }
3904 
3905     /**
3906      * Copies the specified range of the specified array into a new array.
3907      * The initial index of the range ({@code from}) must lie between zero
3908      * and {@code original.length}, inclusive.  The value at
3909      * {@code original[from]} is placed into the initial element of the copy
3910      * (unless {@code from == original.length} or {@code from == to}).
3911      * Values from subsequent elements in the original array are placed into
3912      * subsequent elements in the copy.  The final index of the range
3913      * ({@code to}), which must be greater than or equal to {@code from},
3914      * may be greater than {@code original.length}, in which case
3915      * {@code 0} is placed in all elements of the copy whose index is
3916      * greater than or equal to {@code original.length - from}.  The length
3917      * of the returned array will be {@code to - from}.
3918      *
3919      * @param original the array from which a range is to be copied
3920      * @param from the initial index of the range to be copied, inclusive
3921      * @param to the final index of the range to be copied, exclusive.
3922      *     (This index may lie outside the array.)
3923      * @return a new array containing the specified range from the original array,
3924      *     truncated or padded with zeros to obtain the required length
3925      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
3926      *     or {@code from > original.length}
3927      * @throws IllegalArgumentException if {@code from > to}
3928      * @throws NullPointerException if {@code original} is null
3929      * @since 1.6
3930      */
3931     public static int[] copyOfRange(int[] original, int from, int to) {
3932         if (from == 0 && to == original.length) {
3933             return original.clone();
3934         }
3935         int newLength = to - from;
3936         if (newLength < 0) {
3937             throw new IllegalArgumentException(from + " > " + to);
3938         }
3939         int[] copy = new int[newLength];
3940         System.arraycopy(original, from, copy, 0,
3941                          Math.min(original.length - from, newLength));
3942         return copy;
3943     }
3944 
3945     /**
3946      * Copies the specified range of the specified array into a new array.
3947      * The initial index of the range ({@code from}) must lie between zero
3948      * and {@code original.length}, inclusive.  The value at
3949      * {@code original[from]} is placed into the initial element of the copy
3950      * (unless {@code from == original.length} or {@code from == to}).
3951      * Values from subsequent elements in the original array are placed into
3952      * subsequent elements in the copy.  The final index of the range
3953      * ({@code to}), which must be greater than or equal to {@code from},
3954      * may be greater than {@code original.length}, in which case
3955      * {@code 0L} is placed in all elements of the copy whose index is
3956      * greater than or equal to {@code original.length - from}.  The length
3957      * of the returned array will be {@code to - from}.
3958      *
3959      * @param original the array from which a range is to be copied
3960      * @param from the initial index of the range to be copied, inclusive
3961      * @param to the final index of the range to be copied, exclusive.
3962      *     (This index may lie outside the array.)
3963      * @return a new array containing the specified range from the original array,
3964      *     truncated or padded with zeros to obtain the required length
3965      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
3966      *     or {@code from > original.length}
3967      * @throws IllegalArgumentException if {@code from > to}
3968      * @throws NullPointerException if {@code original} is null
3969      * @since 1.6
3970      */
3971     public static long[] copyOfRange(long[] original, int from, int to) {
3972         if (from == 0 && to == original.length) {
3973             return original.clone();
3974         }
3975         int newLength = to - from;
3976         if (newLength < 0) {
3977             throw new IllegalArgumentException(from + " > " + to);
3978         }
3979         long[] copy = new long[newLength];
3980         System.arraycopy(original, from, copy, 0,
3981                          Math.min(original.length - from, newLength));
3982         return copy;
3983     }
3984 
3985     /**
3986      * Copies the specified range of the specified array into a new array.
3987      * The initial index of the range ({@code from}) must lie between zero
3988      * and {@code original.length}, inclusive.  The value at
3989      * {@code original[from]} is placed into the initial element of the copy
3990      * (unless {@code from == original.length} or {@code from == to}).
3991      * Values from subsequent elements in the original array are placed into
3992      * subsequent elements in the copy.  The final index of the range
3993      * ({@code to}), which must be greater than or equal to {@code from},
3994      * may be greater than {@code original.length}, in which case
3995      * {@code '\u005cu0000'} is placed in all elements of the copy whose index is
3996      * greater than or equal to {@code original.length - from}.  The length
3997      * of the returned array will be {@code to - from}.
3998      *
3999      * @param original the array from which a range is to be copied
4000      * @param from the initial index of the range to be copied, inclusive
4001      * @param to the final index of the range to be copied, exclusive.
4002      *     (This index may lie outside the array.)
4003      * @return a new array containing the specified range from the original array,
4004      *     truncated or padded with null characters to obtain the required length
4005      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
4006      *     or {@code from > original.length}
4007      * @throws IllegalArgumentException if {@code from > to}
4008      * @throws NullPointerException if {@code original} is null
4009      * @since 1.6
4010      */
4011     public static char[] copyOfRange(char[] original, int from, int to) {
4012         if (from == 0 && to == original.length) {
4013             return original.clone();
4014         }
4015         int newLength = to - from;
4016         if (newLength < 0) {
4017             throw new IllegalArgumentException(from + " > " + to);
4018         }
4019         char[] copy = new char[newLength];
4020         System.arraycopy(original, from, copy, 0,
4021                          Math.min(original.length - from, newLength));
4022         return copy;
4023     }
4024 
4025     /**
4026      * Copies the specified range of the specified array into a new array.
4027      * The initial index of the range ({@code from}) must lie between zero
4028      * and {@code original.length}, inclusive.  The value at
4029      * {@code original[from]} is placed into the initial element of the copy
4030      * (unless {@code from == original.length} or {@code from == to}).
4031      * Values from subsequent elements in the original array are placed into
4032      * subsequent elements in the copy.  The final index of the range
4033      * ({@code to}), which must be greater than or equal to {@code from},
4034      * may be greater than {@code original.length}, in which case
4035      * {@code 0f} is placed in all elements of the copy whose index is
4036      * greater than or equal to {@code original.length - from}.  The length
4037      * of the returned array will be {@code to - from}.
4038      *
4039      * @param original the array from which a range is to be copied
4040      * @param from the initial index of the range to be copied, inclusive
4041      * @param to the final index of the range to be copied, exclusive.
4042      *     (This index may lie outside the array.)
4043      * @return a new array containing the specified range from the original array,
4044      *     truncated or padded with zeros to obtain the required length
4045      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
4046      *     or {@code from > original.length}
4047      * @throws IllegalArgumentException if {@code from > to}
4048      * @throws NullPointerException if {@code original} is null
4049      * @since 1.6
4050      */
4051     public static float[] copyOfRange(float[] original, int from, int to) {
4052         if (from == 0 && to == original.length) {
4053             return original.clone();
4054         }
4055         int newLength = to - from;
4056         if (newLength < 0) {
4057             throw new IllegalArgumentException(from + " > " + to);
4058         }
4059         float[] copy = new float[newLength];
4060         System.arraycopy(original, from, copy, 0,
4061                          Math.min(original.length - from, newLength));
4062         return copy;
4063     }
4064 
4065     /**
4066      * Copies the specified range of the specified array into a new array.
4067      * The initial index of the range ({@code from}) must lie between zero
4068      * and {@code original.length}, inclusive.  The value at
4069      * {@code original[from]} is placed into the initial element of the copy
4070      * (unless {@code from == original.length} or {@code from == to}).
4071      * Values from subsequent elements in the original array are placed into
4072      * subsequent elements in the copy.  The final index of the range
4073      * ({@code to}), which must be greater than or equal to {@code from},
4074      * may be greater than {@code original.length}, in which case
4075      * {@code 0d} is placed in all elements of the copy whose index is
4076      * greater than or equal to {@code original.length - from}.  The length
4077      * of the returned array will be {@code to - from}.
4078      *
4079      * @param original the array from which a range is to be copied
4080      * @param from the initial index of the range to be copied, inclusive
4081      * @param to the final index of the range to be copied, exclusive.
4082      *     (This index may lie outside the array.)
4083      * @return a new array containing the specified range from the original array,
4084      *     truncated or padded with zeros to obtain the required length
4085      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
4086      *     or {@code from > original.length}
4087      * @throws IllegalArgumentException if {@code from > to}
4088      * @throws NullPointerException if {@code original} is null
4089      * @since 1.6
4090      */
4091     public static double[] copyOfRange(double[] original, int from, int to) {
4092         if (from == 0 && to == original.length) {
4093             return original.clone();
4094         }
4095         int newLength = to - from;
4096         if (newLength < 0) {
4097             throw new IllegalArgumentException(from + " > " + to);
4098         }
4099         double[] copy = new double[newLength];
4100         System.arraycopy(original, from, copy, 0,
4101                          Math.min(original.length - from, newLength));
4102         return copy;
4103     }
4104 
4105     /**
4106      * Copies the specified range of the specified array into a new array.
4107      * The initial index of the range ({@code from}) must lie between zero
4108      * and {@code original.length}, inclusive.  The value at
4109      * {@code original[from]} is placed into the initial element of the copy
4110      * (unless {@code from == original.length} or {@code from == to}).
4111      * Values from subsequent elements in the original array are placed into
4112      * subsequent elements in the copy.  The final index of the range
4113      * ({@code to}), which must be greater than or equal to {@code from},
4114      * may be greater than {@code original.length}, in which case
4115      * {@code false} is placed in all elements of the copy whose index is
4116      * greater than or equal to {@code original.length - from}.  The length
4117      * of the returned array will be {@code to - from}.
4118      *
4119      * @param original the array from which a range is to be copied
4120      * @param from the initial index of the range to be copied, inclusive
4121      * @param to the final index of the range to be copied, exclusive.
4122      *     (This index may lie outside the array.)
4123      * @return a new array containing the specified range from the original array,
4124      *     truncated or padded with false elements to obtain the required length
4125      * @throws ArrayIndexOutOfBoundsException if {@code from < 0}
4126      *     or {@code from > original.length}
4127      * @throws IllegalArgumentException if {@code from > to}
4128      * @throws NullPointerException if {@code original} is null
4129      * @since 1.6
4130      */
4131     public static boolean[] copyOfRange(boolean[] original, int from, int to) {
4132         if (from == 0 && to == original.length) {
4133             return original.clone();
4134         }
4135         int newLength = to - from;
4136         if (newLength < 0) {
4137             throw new IllegalArgumentException(from + " > " + to);
4138         }
4139         boolean[] copy = new boolean[newLength];
4140         System.arraycopy(original, from, copy, 0,
4141                          Math.min(original.length - from, newLength));
4142         return copy;
4143     }
4144 
4145     // Misc
4146 
4147     /**
4148      * Returns a fixed-size list backed by the specified array. Changes made to
4149      * the array will be visible in the returned list, and changes made to the
4150      * list will be visible in the array. The returned list is
4151      * {@link Serializable} and implements {@link RandomAccess}.
4152      *
4153      * <p>The returned list implements the optional {@code Collection} methods, except
4154      * those that would change the size of the returned list. Those methods leave
4155      * the list unchanged and throw {@link UnsupportedOperationException}.
4156      *
4157      * <p>If the specified array's actual component type differs from the type
4158      * parameter T, this can result in operations on the returned list throwing an
4159      * {@code ArrayStoreException}.
4160      *
4161      * @apiNote
4162      * This method acts as bridge between array-based and collection-based
4163      * APIs, in combination with {@link Collection#toArray}.
4164      *
4165      * <p>This method provides a way to wrap an existing array:
4166      * <pre>{@code
4167      *     Integer[] numbers = ...
4168      *     ...
4169      *     List<Integer> values = Arrays.asList(numbers);
4170      * }</pre>
4171      *
4172      * <p>This method also provides a convenient way to create a fixed-size
4173      * list initialized to contain several elements:
4174      * <pre>{@code
4175      *     List<String> stooges = Arrays.asList("Larry", "Moe", "Curly");
4176      * }</pre>
4177      *
4178      * <p><em>The list returned by this method is modifiable.</em>
4179      * To create an unmodifiable list, use
4180      * {@link Collections#unmodifiableList Collections.unmodifiableList}
4181      * or <a href="List.html#unmodifiable">Unmodifiable Lists</a>.
4182      *
4183      * @param <T> the class of the objects in the array
4184      * @param a the array by which the list will be backed
4185      * @return a list view of the specified array
4186      * @throws NullPointerException if the specified array is {@code null}
4187      */
4188     @SafeVarargs
4189     @SuppressWarnings("varargs")
4190     public static <T> List<T> asList(T... a) {
4191         return new ArrayList<>(a);
4192     }
4193 
4194     /**
4195      * @serial include
4196      */
4197     private static class ArrayList<E> extends AbstractList<E>
4198         implements RandomAccess, java.io.Serializable
4199     {
4200         @java.io.Serial
4201         private static final long serialVersionUID = -2764017481108945198L;
4202         @SuppressWarnings("serial") // Conditionally serializable
4203         private final E[] a;
4204 
4205         ArrayList(E[] array) {
4206             a = Objects.requireNonNull(array);
4207         }
4208 
4209         @Override
4210         public int size() {
4211             return a.length;
4212         }
4213 
4214         @Override
4215         public Object[] toArray() {
4216             return Arrays.copyOf(a, a.length, Object[].class);
4217         }
4218 
4219         @Override
4220         @SuppressWarnings("unchecked")
4221         public <T> T[] toArray(T[] a) {
4222             int size = size();
4223             if (a.length < size)
4224                 return Arrays.copyOf(this.a, size,
4225                                      (Class<? extends T[]>) a.getClass());
4226             System.arraycopy(this.a, 0, a, 0, size);
4227             if (a.length > size)
4228                 a[size] = null;
4229             return a;
4230         }
4231 
4232         @Override
4233         public E get(int index) {
4234             return a[index];
4235         }
4236 
4237         @Override
4238         public E set(int index, E element) {
4239             E oldValue = a[index];
4240             a[index] = element;
4241             return oldValue;
4242         }
4243 
4244         @Override
4245         public int indexOf(Object o) {
4246             E[] a = this.a;
4247             if (o == null) {
4248                 for (int i = 0; i < a.length; i++)
4249                     if (a[i] == null)
4250                         return i;
4251             } else {
4252                 for (int i = 0; i < a.length; i++)
4253                     if (o.equals(a[i]))
4254                         return i;
4255             }
4256             return -1;
4257         }
4258 
4259         @Override
4260         public boolean contains(Object o) {
4261             return indexOf(o) >= 0;
4262         }
4263 
4264         @Override
4265         public Spliterator<E> spliterator() {
4266             return Spliterators.spliterator(a, Spliterator.ORDERED);
4267         }
4268 
4269         @Override
4270         public void forEach(Consumer<? super E> action) {
4271             Objects.requireNonNull(action);
4272             for (E e : a) {
4273                 action.accept(e);
4274             }
4275         }
4276 
4277         @Override
4278         public void replaceAll(UnaryOperator<E> operator) {
4279             Objects.requireNonNull(operator);
4280             E[] a = this.a;
4281             for (int i = 0; i < a.length; i++) {
4282                 a[i] = operator.apply(a[i]);
4283             }
4284         }
4285 
4286         @Override
4287         public void sort(Comparator<? super E> c) {
4288             Arrays.sort(a, c);
4289         }
4290 
4291         @Override
4292         public Iterator<E> iterator() {
4293             return new ArrayItr<>(a);
4294         }
4295     }
4296 
4297     private static class ArrayItr<E> implements Iterator<E> {
4298         private int cursor;
4299         private final E[] a;
4300 
4301         ArrayItr(E[] a) {
4302             this.a = a;
4303         }
4304 
4305         @Override
4306         public boolean hasNext() {
4307             return cursor < a.length;
4308         }
4309 
4310         @Override
4311         public E next() {
4312             int i = cursor;
4313             if (i >= a.length) {
4314                 throw new NoSuchElementException();
4315             }
4316             cursor = i + 1;
4317             return a[i];
4318         }
4319     }
4320 
4321     /**
4322      * Returns a hash code based on the contents of the specified array.
4323      * For any two {@code long} arrays {@code a} and {@code b}
4324      * such that {@code Arrays.equals(a, b)}, it is also the case that
4325      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4326      *
4327      * <p>The value returned by this method is the same value that would be
4328      * obtained by invoking the {@link List#hashCode() hashCode}
4329      * method on a {@link List} containing a sequence of {@link Long}
4330      * instances representing the elements of {@code a} in the same order.
4331      * If {@code a} is {@code null}, this method returns 0.
4332      *
4333      * @param a the array whose hash value to compute
4334      * @return a content-based hash code for {@code a}
4335      * @since 1.5
4336      */
4337     public static int hashCode(long[] a) {
4338         if (a == null) {
4339             return 0;
4340         }
4341         int result = 1;
4342         for (long element : a) {
4343             result = 31 * result + Long.hashCode(element);
4344         }
4345         return result;
4346     }
4347 
4348     /**
4349      * Returns a hash code based on the contents of the specified array.
4350      * For any two non-null {@code int} arrays {@code a} and {@code b}
4351      * such that {@code Arrays.equals(a, b)}, it is also the case that
4352      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4353      *
4354      * <p>The value returned by this method is the same value that would be
4355      * obtained by invoking the {@link List#hashCode() hashCode}
4356      * method on a {@link List} containing a sequence of {@link Integer}
4357      * instances representing the elements of {@code a} in the same order.
4358      * If {@code a} is {@code null}, this method returns 0.
4359      *
4360      * @param a the array whose hash value to compute
4361      * @return a content-based hash code for {@code a}
4362      * @since 1.5
4363      */
4364     public static int hashCode(int[] a) {
4365         if (a == null) {
4366             return 0;
4367         }
4368         return ArraysSupport.hashCode(a, 0, a.length, 1);
4369     }
4370 
4371     /**
4372      * Returns a hash code based on the contents of the specified array.
4373      * For any two {@code short} arrays {@code a} and {@code b}
4374      * such that {@code Arrays.equals(a, b)}, it is also the case that
4375      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4376      *
4377      * <p>The value returned by this method is the same value that would be
4378      * obtained by invoking the {@link List#hashCode() hashCode}
4379      * method on a {@link List} containing a sequence of {@link Short}
4380      * instances representing the elements of {@code a} in the same order.
4381      * If {@code a} is {@code null}, this method returns 0.
4382      *
4383      * @param a the array whose hash value to compute
4384      * @return a content-based hash code for {@code a}
4385      * @since 1.5
4386      */
4387     public static int hashCode(short[] a) {
4388         if (a == null) {
4389             return 0;
4390         }
4391         return ArraysSupport.hashCode(a, 0, a.length, 1);
4392     }
4393 
4394     /**
4395      * Returns a hash code based on the contents of the specified array.
4396      * For any two {@code char} arrays {@code a} and {@code b}
4397      * such that {@code Arrays.equals(a, b)}, it is also the case that
4398      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4399      *
4400      * <p>The value returned by this method is the same value that would be
4401      * obtained by invoking the {@link List#hashCode() hashCode}
4402      * method on a {@link List} containing a sequence of {@link Character}
4403      * instances representing the elements of {@code a} in the same order.
4404      * If {@code a} is {@code null}, this method returns 0.
4405      *
4406      * @param a the array whose hash value to compute
4407      * @return a content-based hash code for {@code a}
4408      * @since 1.5
4409      */
4410     public static int hashCode(char[] a) {
4411         if (a == null) {
4412             return 0;
4413         }
4414         return ArraysSupport.hashCode(a, 0, a.length, 1);
4415     }
4416 
4417     /**
4418      * Returns a hash code based on the contents of the specified array.
4419      * For any two {@code byte} arrays {@code a} and {@code b}
4420      * such that {@code Arrays.equals(a, b)}, it is also the case that
4421      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4422      *
4423      * <p>The value returned by this method is the same value that would be
4424      * obtained by invoking the {@link List#hashCode() hashCode}
4425      * method on a {@link List} containing a sequence of {@link Byte}
4426      * instances representing the elements of {@code a} in the same order.
4427      * If {@code a} is {@code null}, this method returns 0.
4428      *
4429      * @param a the array whose hash value to compute
4430      * @return a content-based hash code for {@code a}
4431      * @since 1.5
4432      */
4433     public static int hashCode(byte[] a) {
4434         if (a == null) {
4435             return 0;
4436         }
4437         return ArraysSupport.hashCode(a, 0, a.length, 1);
4438     }
4439 
4440     /**
4441      * Returns a hash code based on the contents of the specified array.
4442      * For any two {@code boolean} arrays {@code a} and {@code b}
4443      * such that {@code Arrays.equals(a, b)}, it is also the case that
4444      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4445      *
4446      * <p>The value returned by this method is the same value that would be
4447      * obtained by invoking the {@link List#hashCode() hashCode}
4448      * method on a {@link List} containing a sequence of {@link Boolean}
4449      * instances representing the elements of {@code a} in the same order.
4450      * If {@code a} is {@code null}, this method returns 0.
4451      *
4452      * @param a the array whose hash value to compute
4453      * @return a content-based hash code for {@code a}
4454      * @since 1.5
4455      */
4456     public static int hashCode(boolean[] a) {
4457         if (a == null)
4458             return 0;
4459 
4460         int result = 1;
4461         for (boolean element : a)
4462             result = 31 * result + Boolean.hashCode(element);
4463 
4464         return result;
4465     }
4466 
4467     /**
4468      * Returns a hash code based on the contents of the specified array.
4469      * For any two {@code float} arrays {@code a} and {@code b}
4470      * such that {@code Arrays.equals(a, b)}, it is also the case that
4471      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4472      *
4473      * <p>The value returned by this method is the same value that would be
4474      * obtained by invoking the {@link List#hashCode() hashCode}
4475      * method on a {@link List} containing a sequence of {@link Float}
4476      * instances representing the elements of {@code a} in the same order.
4477      * If {@code a} is {@code null}, this method returns 0.
4478      *
4479      * @param a the array whose hash value to compute
4480      * @return a content-based hash code for {@code a}
4481      * @since 1.5
4482      */
4483     public static int hashCode(float[] a) {
4484         if (a == null)
4485             return 0;
4486 
4487         int result = 1;
4488         for (float element : a)
4489             result = 31 * result + Float.hashCode(element);
4490 
4491         return result;
4492     }
4493 
4494     /**
4495      * Returns a hash code based on the contents of the specified array.
4496      * For any two {@code double} arrays {@code a} and {@code b}
4497      * such that {@code Arrays.equals(a, b)}, it is also the case that
4498      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4499      *
4500      * <p>The value returned by this method is the same value that would be
4501      * obtained by invoking the {@link List#hashCode() hashCode}
4502      * method on a {@link List} containing a sequence of {@link Double}
4503      * instances representing the elements of {@code a} in the same order.
4504      * If {@code a} is {@code null}, this method returns 0.
4505      *
4506      * @param a the array whose hash value to compute
4507      * @return a content-based hash code for {@code a}
4508      * @since 1.5
4509      */
4510     public static int hashCode(double[] a) {
4511         if (a == null)
4512             return 0;
4513 
4514         int result = 1;
4515         for (double element : a) {
4516             result = 31 * result + Double.hashCode(element);
4517         }
4518         return result;
4519     }
4520 
4521     /**
4522      * Returns a hash code based on the contents of the specified array.  If
4523      * the array contains other arrays as elements, the hash code is based on
4524      * their identities rather than their contents.  It is therefore
4525      * acceptable to invoke this method on an array that contains itself as an
4526      * element,  either directly or indirectly through one or more levels of
4527      * arrays.
4528      *
4529      * <p>For any two arrays {@code a} and {@code b} such that
4530      * {@code Arrays.equals(a, b)}, it is also the case that
4531      * {@code Arrays.hashCode(a) == Arrays.hashCode(b)}.
4532      *
4533      * <p>The value returned by this method is equal to the value that would
4534      * be returned by {@code Arrays.asList(a).hashCode()}, unless {@code a}
4535      * is {@code null}, in which case {@code 0} is returned.
4536      *
4537      * @param a the array whose content-based hash code to compute
4538      * @return a content-based hash code for {@code a}
4539      * @see #deepHashCode(Object[])
4540      * @since 1.5
4541      */
4542     public static int hashCode(Object[] a) {
4543         if (a == null) {
4544             return 0;
4545         }
4546         return ArraysSupport.hashCode(a, 0, a.length, 1);
4547     }
4548 
4549     /**
4550      * Returns a hash code based on the "deep contents" of the specified
4551      * array.  If the array contains other arrays as elements, the
4552      * hash code is based on their contents and so on, ad infinitum.
4553      * It is therefore unacceptable to invoke this method on an array that
4554      * contains itself as an element, either directly or indirectly through
4555      * one or more levels of arrays.  The behavior of such an invocation is
4556      * undefined.
4557      *
4558      * <p>For any two arrays {@code a} and {@code b} such that
4559      * {@code Arrays.deepEquals(a, b)}, it is also the case that
4560      * {@code Arrays.deepHashCode(a) == Arrays.deepHashCode(b)}.
4561      *
4562      * <p>The computation of the value returned by this method is similar to
4563      * that of the value returned by {@link List#hashCode()} on a list
4564      * containing the same elements as {@code a} in the same order, with one
4565      * difference: If an element {@code e} of {@code a} is itself an array,
4566      * its hash code is computed not by calling {@code e.hashCode()}, but as
4567      * by calling the appropriate overloading of {@code Arrays.hashCode(e)}
4568      * if {@code e} is an array of a primitive type, or as by calling
4569      * {@code Arrays.deepHashCode(e)} recursively if {@code e} is an array
4570      * of a reference type.  If {@code a} is {@code null}, this method
4571      * returns 0.
4572      *
4573      * @param a the array whose deep-content-based hash code to compute
4574      * @return a deep-content-based hash code for {@code a}
4575      * @see #hashCode(Object[])
4576      * @since 1.5
4577      */
4578     public static int deepHashCode(Object[] a) {
4579         if (a == null)
4580             return 0;
4581 
4582         int result = 1;
4583 
4584         for (Object element : a) {
4585             final int elementHash;
4586             final Class<?> cl;
4587             if (element == null)
4588                 elementHash = 0;
4589             else if ((cl = element.getClass().getComponentType()) == null)
4590                 elementHash = element.hashCode();
4591             else if (element instanceof Object[])
4592                 elementHash = deepHashCode((Object[]) element);
4593             else
4594                 elementHash = primitiveArrayHashCode(element, cl);
4595 
4596             result = 31 * result + elementHash;
4597         }
4598 
4599         return result;
4600     }
4601 
4602     private static int primitiveArrayHashCode(Object a, Class<?> cl) {
4603         return
4604             (cl == byte.class)    ? hashCode((byte[]) a)    :
4605             (cl == int.class)     ? hashCode((int[]) a)     :
4606             (cl == long.class)    ? hashCode((long[]) a)    :
4607             (cl == char.class)    ? hashCode((char[]) a)    :
4608             (cl == short.class)   ? hashCode((short[]) a)   :
4609             (cl == boolean.class) ? hashCode((boolean[]) a) :
4610             (cl == double.class)  ? hashCode((double[]) a)  :
4611             // If new primitive types are ever added, this method must be
4612             // expanded or we will fail here with ClassCastException.
4613             hashCode((float[]) a);
4614     }
4615 
4616     /**
4617      * Returns {@code true} if the two specified arrays are <i>deeply
4618      * equal</i> to one another.  Unlike the {@link #equals(Object[],Object[])}
4619      * method, this method is appropriate for use with nested arrays of
4620      * arbitrary depth.
4621      *
4622      * <p>Two array references are considered deeply equal if both
4623      * are {@code null}, or if they refer to arrays that contain the same
4624      * number of elements and all corresponding pairs of elements in the two
4625      * arrays are deeply equal.
4626      *
4627      * <p>Two possibly {@code null} elements {@code e1} and {@code e2} are
4628      * deeply equal if any of the following conditions hold:
4629      * <ul>
4630      *    <li> {@code e1} and {@code e2} are both arrays of object reference
4631      *         types, and {@code Arrays.deepEquals(e1, e2) would return true}
4632      *    <li> {@code e1} and {@code e2} are arrays of the same primitive
4633      *         type, and the appropriate overloading of
4634      *         {@code Arrays.equals(e1, e2)} would return true.
4635      *    <li> {@code e1 == e2}
4636      *    <li> {@code e1.equals(e2)} would return true.
4637      * </ul>
4638      * Note that this definition permits {@code null} elements at any depth.
4639      *
4640      * <p>If either of the specified arrays contain themselves as elements
4641      * either directly or indirectly through one or more levels of arrays,
4642      * the behavior of this method is undefined.
4643      *
4644      * @param a1 one array to be tested for equality
4645      * @param a2 the other array to be tested for equality
4646      * @return {@code true} if the two arrays are equal
4647      * @see #equals(Object[],Object[])
4648      * @see Objects#deepEquals(Object, Object)
4649      * @since 1.5
4650      */
4651     public static boolean deepEquals(Object[] a1, Object[] a2) {
4652         if (a1 == a2)
4653             return true;
4654         if (a1 == null || a2==null)
4655             return false;
4656         int length = a1.length;
4657         if (a2.length != length)
4658             return false;
4659 
4660         for (int i = 0; i < length; i++) {
4661             Object e1 = a1[i];
4662             Object e2 = a2[i];
4663 
4664             if (e1 == e2)
4665                 continue;
4666             if (e1 == null)
4667                 return false;
4668 
4669             // Figure out whether the two elements are equal
4670             boolean eq = deepEquals0(e1, e2);
4671 
4672             if (!eq)
4673                 return false;
4674         }
4675         return true;
4676     }
4677 
4678     static boolean deepEquals0(Object e1, Object e2) {
4679         assert e1 != null;
4680         boolean eq;
4681         if (e1 instanceof Object[] && e2 instanceof Object[])
4682             eq = deepEquals ((Object[]) e1, (Object[]) e2);
4683         else if (e1 instanceof byte[] && e2 instanceof byte[])
4684             eq = equals((byte[]) e1, (byte[]) e2);
4685         else if (e1 instanceof short[] && e2 instanceof short[])
4686             eq = equals((short[]) e1, (short[]) e2);
4687         else if (e1 instanceof int[] && e2 instanceof int[])
4688             eq = equals((int[]) e1, (int[]) e2);
4689         else if (e1 instanceof long[] && e2 instanceof long[])
4690             eq = equals((long[]) e1, (long[]) e2);
4691         else if (e1 instanceof char[] && e2 instanceof char[])
4692             eq = equals((char[]) e1, (char[]) e2);
4693         else if (e1 instanceof float[] && e2 instanceof float[])
4694             eq = equals((float[]) e1, (float[]) e2);
4695         else if (e1 instanceof double[] && e2 instanceof double[])
4696             eq = equals((double[]) e1, (double[]) e2);
4697         else if (e1 instanceof boolean[] && e2 instanceof boolean[])
4698             eq = equals((boolean[]) e1, (boolean[]) e2);
4699         else
4700             eq = e1.equals(e2);
4701         return eq;
4702     }
4703 
4704     /**
4705      * Returns a string representation of the contents of the specified array.
4706      * The string representation consists of a list of the array's elements,
4707      * enclosed in square brackets ({@code "[]"}).  Adjacent elements are
4708      * separated by the characters {@code ", "} (a comma followed by a
4709      * space).  Elements are converted to strings as by
4710      * {@code String.valueOf(long)}.  Returns {@code "null"} if {@code a}
4711      * is {@code null}.
4712      *
4713      * @param a the array whose string representation to return
4714      * @return a string representation of {@code a}
4715      * @since 1.5
4716      */
4717     public static String toString(long[] a) {
4718         if (a == null)
4719             return "null";
4720         int iMax = a.length - 1;
4721         if (iMax == -1)
4722             return "[]";
4723 
4724         StringBuilder b = new StringBuilder();
4725         b.append('[');
4726         for (int i = 0; ; i++) {
4727             b.append(a[i]);
4728             if (i == iMax)
4729                 return b.append(']').toString();
4730             b.append(", ");
4731         }
4732     }
4733 
4734     /**
4735      * Returns a string representation of the contents of the specified array.
4736      * The string representation consists of a list of the array's elements,
4737      * enclosed in square brackets ({@code "[]"}).  Adjacent elements are
4738      * separated by the characters {@code ", "} (a comma followed by a
4739      * space).  Elements are converted to strings as by
4740      * {@code String.valueOf(int)}.  Returns {@code "null"} if {@code a} is
4741      * {@code null}.
4742      *
4743      * @param a the array whose string representation to return
4744      * @return a string representation of {@code a}
4745      * @since 1.5
4746      */
4747     public static String toString(int[] a) {
4748         if (a == null)
4749             return "null";
4750         int iMax = a.length - 1;
4751         if (iMax == -1)
4752             return "[]";
4753 
4754         StringBuilder b = new StringBuilder();
4755         b.append('[');
4756         for (int i = 0; ; i++) {
4757             b.append(a[i]);
4758             if (i == iMax)
4759                 return b.append(']').toString();
4760             b.append(", ");
4761         }
4762     }
4763 
4764     /**
4765      * Returns a string representation of the contents of the specified array.
4766      * The string representation consists of a list of the array's elements,
4767      * enclosed in square brackets ({@code "[]"}).  Adjacent elements are
4768      * separated by the characters {@code ", "} (a comma followed by a
4769      * space).  Elements are converted to strings as by
4770      * {@code String.valueOf(short)}.  Returns {@code "null"} if {@code a}
4771      * is {@code null}.
4772      *
4773      * @param a the array whose string representation to return
4774      * @return a string representation of {@code a}
4775      * @since 1.5
4776      */
4777     public static String toString(short[] a) {
4778         if (a == null)
4779             return "null";
4780         int iMax = a.length - 1;
4781         if (iMax == -1)
4782             return "[]";
4783 
4784         StringBuilder b = new StringBuilder();
4785         b.append('[');
4786         for (int i = 0; ; i++) {
4787             b.append(a[i]);
4788             if (i == iMax)
4789                 return b.append(']').toString();
4790             b.append(", ");
4791         }
4792     }
4793 
4794     /**
4795      * Returns a string representation of the contents of the specified array.
4796      * The string representation consists of a list of the array's elements,
4797      * enclosed in square brackets ({@code "[]"}).  Adjacent elements are
4798      * separated by the characters {@code ", "} (a comma followed by a
4799      * space).  Elements are converted to strings as by
4800      * {@code String.valueOf(char)}.  Returns {@code "null"} if {@code a}
4801      * is {@code null}.
4802      *
4803      * @param a the array whose string representation to return
4804      * @return a string representation of {@code a}
4805      * @since 1.5
4806      */
4807     public static String toString(char[] a) {
4808         if (a == null)
4809             return "null";
4810         int iMax = a.length - 1;
4811         if (iMax == -1)
4812             return "[]";
4813 
4814         StringBuilder b = new StringBuilder();
4815         b.append('[');
4816         for (int i = 0; ; i++) {
4817             b.append(a[i]);
4818             if (i == iMax)
4819                 return b.append(']').toString();
4820             b.append(", ");
4821         }
4822     }
4823 
4824     /**
4825      * Returns a string representation of the contents of the specified array.
4826      * The string representation consists of a list of the array's elements,
4827      * enclosed in square brackets ({@code "[]"}).  Adjacent elements
4828      * are separated by the characters {@code ", "} (a comma followed
4829      * by a space).  Elements are converted to strings as by
4830      * {@code String.valueOf(byte)}.  Returns {@code "null"} if
4831      * {@code a} is {@code null}.
4832      *
4833      * @param a the array whose string representation to return
4834      * @return a string representation of {@code a}
4835      * @since 1.5
4836      */
4837     public static String toString(byte[] a) {
4838         if (a == null)
4839             return "null";
4840         int iMax = a.length - 1;
4841         if (iMax == -1)
4842             return "[]";
4843 
4844         StringBuilder b = new StringBuilder();
4845         b.append('[');
4846         for (int i = 0; ; i++) {
4847             b.append(a[i]);
4848             if (i == iMax)
4849                 return b.append(']').toString();
4850             b.append(", ");
4851         }
4852     }
4853 
4854     /**
4855      * Returns a string representation of the contents of the specified array.
4856      * The string representation consists of a list of the array's elements,
4857      * enclosed in square brackets ({@code "[]"}).  Adjacent elements are
4858      * separated by the characters {@code ", "} (a comma followed by a
4859      * space).  Elements are converted to strings as by
4860      * {@code String.valueOf(boolean)}.  Returns {@code "null"} if
4861      * {@code a} is {@code null}.
4862      *
4863      * @param a the array whose string representation to return
4864      * @return a string representation of {@code a}
4865      * @since 1.5
4866      */
4867     public static String toString(boolean[] a) {
4868         if (a == null)
4869             return "null";
4870         int iMax = a.length - 1;
4871         if (iMax == -1)
4872             return "[]";
4873 
4874         StringBuilder b = new StringBuilder();
4875         b.append('[');
4876         for (int i = 0; ; i++) {
4877             b.append(a[i]);
4878             if (i == iMax)
4879                 return b.append(']').toString();
4880             b.append(", ");
4881         }
4882     }
4883 
4884     /**
4885      * Returns a string representation of the contents of the specified array.
4886      * The string representation consists of a list of the array's elements,
4887      * enclosed in square brackets ({@code "[]"}).  Adjacent elements are
4888      * separated by the characters {@code ", "} (a comma followed by a
4889      * space).  Elements are converted to strings as by
4890      * {@code String.valueOf(float)}.  Returns {@code "null"} if {@code a}
4891      * is {@code null}.
4892      *
4893      * @param a the array whose string representation to return
4894      * @return a string representation of {@code a}
4895      * @since 1.5
4896      */
4897     public static String toString(float[] a) {
4898         if (a == null)
4899             return "null";
4900 
4901         int iMax = a.length - 1;
4902         if (iMax == -1)
4903             return "[]";
4904 
4905         StringBuilder b = new StringBuilder();
4906         b.append('[');
4907         for (int i = 0; ; i++) {
4908             b.append(a[i]);
4909             if (i == iMax)
4910                 return b.append(']').toString();
4911             b.append(", ");
4912         }
4913     }
4914 
4915     /**
4916      * Returns a string representation of the contents of the specified array.
4917      * The string representation consists of a list of the array's elements,
4918      * enclosed in square brackets ({@code "[]"}).  Adjacent elements are
4919      * separated by the characters {@code ", "} (a comma followed by a
4920      * space).  Elements are converted to strings as by
4921      * {@code String.valueOf(double)}.  Returns {@code "null"} if {@code a}
4922      * is {@code null}.
4923      *
4924      * @param a the array whose string representation to return
4925      * @return a string representation of {@code a}
4926      * @since 1.5
4927      */
4928     public static String toString(double[] a) {
4929         if (a == null)
4930             return "null";
4931         int iMax = a.length - 1;
4932         if (iMax == -1)
4933             return "[]";
4934 
4935         StringBuilder b = new StringBuilder();
4936         b.append('[');
4937         for (int i = 0; ; i++) {
4938             b.append(a[i]);
4939             if (i == iMax)
4940                 return b.append(']').toString();
4941             b.append(", ");
4942         }
4943     }
4944 
4945     /**
4946      * Returns a string representation of the contents of the specified array.
4947      * If the array contains other arrays as elements, they are converted to
4948      * strings by the {@link Object#toString} method inherited from
4949      * {@code Object}, which describes their <i>identities</i> rather than
4950      * their contents.
4951      *
4952      * <p>The value returned by this method is equal to the value that would
4953      * be returned by {@code Arrays.asList(a).toString()}, unless {@code a}
4954      * is {@code null}, in which case {@code "null"} is returned.
4955      *
4956      * @param a the array whose string representation to return
4957      * @return a string representation of {@code a}
4958      * @see #deepToString(Object[])
4959      * @since 1.5
4960      */
4961     public static String toString(Object[] a) {
4962         if (a == null)
4963             return "null";
4964 
4965         int iMax = a.length - 1;
4966         if (iMax == -1)
4967             return "[]";
4968 
4969         StringBuilder b = new StringBuilder();
4970         b.append('[');
4971         for (int i = 0; ; i++) {
4972             b.append(String.valueOf(a[i]));
4973             if (i == iMax)
4974                 return b.append(']').toString();
4975             b.append(", ");
4976         }
4977     }
4978 
4979     /**
4980      * Returns a string representation of the "deep contents" of the specified
4981      * array.  If the array contains other arrays as elements, the string
4982      * representation contains their contents and so on.  This method is
4983      * designed for converting multidimensional arrays to strings.
4984      *
4985      * <p>The string representation consists of a list of the array's
4986      * elements, enclosed in square brackets ({@code "[]"}).  Adjacent
4987      * elements are separated by the characters {@code ", "} (a comma
4988      * followed by a space).  Elements are converted to strings as by
4989      * {@code String.valueOf(Object)}, unless they are themselves
4990      * arrays.
4991      *
4992      * <p>If an element {@code e} is an array of a primitive type, it is
4993      * converted to a string as by invoking the appropriate overloading of
4994      * {@code Arrays.toString(e)}.  If an element {@code e} is an array of a
4995      * reference type, it is converted to a string as by invoking
4996      * this method recursively.
4997      *
4998      * <p>To avoid infinite recursion, if the specified array contains itself
4999      * as an element, or contains an indirect reference to itself through one
5000      * or more levels of arrays, the self-reference is converted to the string
5001      * {@code "[...]"}.  For example, an array containing only a reference
5002      * to itself would be rendered as {@code "[[...]]"}.
5003      *
5004      * <p>This method returns {@code "null"} if the specified array
5005      * is {@code null}.
5006      *
5007      * @param a the array whose string representation to return
5008      * @return a string representation of {@code a}
5009      * @see #toString(Object[])
5010      * @since 1.5
5011      */
5012     public static String deepToString(Object[] a) {
5013         if (a == null)
5014             return "null";
5015 
5016         int bufLen = 20 * a.length;
5017         if (a.length != 0 && bufLen <= 0)
5018             bufLen = Integer.MAX_VALUE;
5019         StringBuilder buf = new StringBuilder(bufLen);
5020         deepToString(a, buf, new HashSet<>());
5021         return buf.toString();
5022     }
5023 
5024     private static void deepToString(Object[] a, StringBuilder buf,
5025                                      Set<Object[]> dejaVu) {
5026         if (a == null) {
5027             buf.append("null");
5028             return;
5029         }
5030         int iMax = a.length - 1;
5031         if (iMax == -1) {
5032             buf.append("[]");
5033             return;
5034         }
5035 
5036         dejaVu.add(a);
5037         buf.append('[');
5038         for (int i = 0; ; i++) {
5039 
5040             Object element = a[i];
5041             if (element == null) {
5042                 buf.append("null");
5043             } else {
5044                 Class<?> eClass = element.getClass();
5045 
5046                 if (eClass.isArray()) {
5047                     if (eClass == byte[].class)
5048                         buf.append(toString((byte[]) element));
5049                     else if (eClass == short[].class)
5050                         buf.append(toString((short[]) element));
5051                     else if (eClass == int[].class)
5052                         buf.append(toString((int[]) element));
5053                     else if (eClass == long[].class)
5054                         buf.append(toString((long[]) element));
5055                     else if (eClass == char[].class)
5056                         buf.append(toString((char[]) element));
5057                     else if (eClass == float[].class)
5058                         buf.append(toString((float[]) element));
5059                     else if (eClass == double[].class)
5060                         buf.append(toString((double[]) element));
5061                     else if (eClass == boolean[].class)
5062                         buf.append(toString((boolean[]) element));
5063                     else { // element is an array of object references
5064                         if (dejaVu.contains(element))
5065                             buf.append("[...]");
5066                         else
5067                             deepToString((Object[])element, buf, dejaVu);
5068                     }
5069                 } else {  // element is non-null and not an array
5070                     buf.append(element.toString());
5071                 }
5072             }
5073             if (i == iMax)
5074                 break;
5075             buf.append(", ");
5076         }
5077         buf.append(']');
5078         dejaVu.remove(a);
5079     }
5080 
5081 
5082     /**
5083      * Set all elements of the specified array, using the provided
5084      * generator function to compute each element.
5085      *
5086      * <p>If the generator function throws an exception, it is relayed to
5087      * the caller and the array is left in an indeterminate state.
5088      *
5089      * @apiNote
5090      * Setting a subrange of an array, using a generator function to compute
5091      * each element, can be written as follows:
5092      * <pre>{@code
5093      * IntStream.range(startInclusive, endExclusive)
5094      *          .forEach(i -> array[i] = generator.apply(i));
5095      * }</pre>
5096      *
5097      * @param <T> type of elements of the array
5098      * @param array array to be initialized
5099      * @param generator a function accepting an index and producing the desired
5100      *        value for that position
5101      * @throws NullPointerException if the generator is null
5102      * @since 1.8
5103      */
5104     public static <T> void setAll(T[] array, IntFunction<? extends T> generator) {
5105         Objects.requireNonNull(generator);
5106         for (int i = 0; i < array.length; i++)
5107             array[i] = generator.apply(i);
5108     }
5109 
5110     /**
5111      * Set all elements of the specified array, in parallel, using the
5112      * provided generator function to compute each element.
5113      *
5114      * <p>If the generator function throws an exception, an unchecked exception
5115      * is thrown from {@code parallelSetAll} and the array is left in an
5116      * indeterminate state.
5117      *
5118      * @apiNote
5119      * Setting a subrange of an array, in parallel, using a generator function
5120      * to compute each element, can be written as follows:
5121      * <pre>{@code
5122      * IntStream.range(startInclusive, endExclusive)
5123      *          .parallel()
5124      *          .forEach(i -> array[i] = generator.apply(i));
5125      * }</pre>
5126      *
5127      * @param <T> type of elements of the array
5128      * @param array array to be initialized
5129      * @param generator a function accepting an index and producing the desired
5130      *        value for that position
5131      * @throws NullPointerException if the generator is null
5132      * @since 1.8
5133      */
5134     public static <T> void parallelSetAll(T[] array, IntFunction<? extends T> generator) {
5135         Objects.requireNonNull(generator);
5136         IntStream.range(0, array.length).parallel().forEach(i -> { array[i] = generator.apply(i); });
5137     }
5138 
5139     /**
5140      * Set all elements of the specified array, using the provided
5141      * generator function to compute each element.
5142      *
5143      * <p>If the generator function throws an exception, it is relayed to
5144      * the caller and the array is left in an indeterminate state.
5145      *
5146      * @apiNote
5147      * Setting a subrange of an array, using a generator function to compute
5148      * each element, can be written as follows:
5149      * <pre>{@code
5150      * IntStream.range(startInclusive, endExclusive)
5151      *          .forEach(i -> array[i] = generator.applyAsInt(i));
5152      * }</pre>
5153      *
5154      * @param array array to be initialized
5155      * @param generator a function accepting an index and producing the desired
5156      *        value for that position
5157      * @throws NullPointerException if the generator is null
5158      * @since 1.8
5159      */
5160     public static void setAll(int[] array, IntUnaryOperator generator) {
5161         Objects.requireNonNull(generator);
5162         for (int i = 0; i < array.length; i++)
5163             array[i] = generator.applyAsInt(i);
5164     }
5165 
5166     /**
5167      * Set all elements of the specified array, in parallel, using the
5168      * provided generator function to compute each element.
5169      *
5170      * <p>If the generator function throws an exception, an unchecked exception
5171      * is thrown from {@code parallelSetAll} and the array is left in an
5172      * indeterminate state.
5173      *
5174      * @apiNote
5175      * Setting a subrange of an array, in parallel, using a generator function
5176      * to compute each element, can be written as follows:
5177      * <pre>{@code
5178      * IntStream.range(startInclusive, endExclusive)
5179      *          .parallel()
5180      *          .forEach(i -> array[i] = generator.applyAsInt(i));
5181      * }</pre>
5182      *
5183      * @param array array to be initialized
5184      * @param generator a function accepting an index and producing the desired
5185      * value for that position
5186      * @throws NullPointerException if the generator is null
5187      * @since 1.8
5188      */
5189     public static void parallelSetAll(int[] array, IntUnaryOperator generator) {
5190         Objects.requireNonNull(generator);
5191         IntStream.range(0, array.length).parallel().forEach(i -> { array[i] = generator.applyAsInt(i); });
5192     }
5193 
5194     /**
5195      * Set all elements of the specified array, using the provided
5196      * generator function to compute each element.
5197      *
5198      * <p>If the generator function throws an exception, it is relayed to
5199      * the caller and the array is left in an indeterminate state.
5200      *
5201      * @apiNote
5202      * Setting a subrange of an array, using a generator function to compute
5203      * each element, can be written as follows:
5204      * <pre>{@code
5205      * IntStream.range(startInclusive, endExclusive)
5206      *          .forEach(i -> array[i] = generator.applyAsLong(i));
5207      * }</pre>
5208      *
5209      * @param array array to be initialized
5210      * @param generator a function accepting an index and producing the desired
5211      *        value for that position
5212      * @throws NullPointerException if the generator is null
5213      * @since 1.8
5214      */
5215     public static void setAll(long[] array, IntToLongFunction generator) {
5216         Objects.requireNonNull(generator);
5217         for (int i = 0; i < array.length; i++)
5218             array[i] = generator.applyAsLong(i);
5219     }
5220 
5221     /**
5222      * Set all elements of the specified array, in parallel, using the
5223      * provided generator function to compute each element.
5224      *
5225      * <p>If the generator function throws an exception, an unchecked exception
5226      * is thrown from {@code parallelSetAll} and the array is left in an
5227      * indeterminate state.
5228      *
5229      * @apiNote
5230      * Setting a subrange of an array, in parallel, using a generator function
5231      * to compute each element, can be written as follows:
5232      * <pre>{@code
5233      * IntStream.range(startInclusive, endExclusive)
5234      *          .parallel()
5235      *          .forEach(i -> array[i] = generator.applyAsLong(i));
5236      * }</pre>
5237      *
5238      * @param array array to be initialized
5239      * @param generator a function accepting an index and producing the desired
5240      *        value for that position
5241      * @throws NullPointerException if the generator is null
5242      * @since 1.8
5243      */
5244     public static void parallelSetAll(long[] array, IntToLongFunction generator) {
5245         Objects.requireNonNull(generator);
5246         IntStream.range(0, array.length).parallel().forEach(i -> { array[i] = generator.applyAsLong(i); });
5247     }
5248 
5249     /**
5250      * Set all elements of the specified array, using the provided
5251      * generator function to compute each element.
5252      *
5253      * <p>If the generator function throws an exception, it is relayed to
5254      * the caller and the array is left in an indeterminate state.
5255      *
5256      * @apiNote
5257      * Setting a subrange of an array, using a generator function to compute
5258      * each element, can be written as follows:
5259      * <pre>{@code
5260      * IntStream.range(startInclusive, endExclusive)
5261      *          .forEach(i -> array[i] = generator.applyAsDouble(i));
5262      * }</pre>
5263      *
5264      * @param array array to be initialized
5265      * @param generator a function accepting an index and producing the desired
5266      *        value for that position
5267      * @throws NullPointerException if the generator is null
5268      * @since 1.8
5269      */
5270     public static void setAll(double[] array, IntToDoubleFunction generator) {
5271         Objects.requireNonNull(generator);
5272         for (int i = 0; i < array.length; i++)
5273             array[i] = generator.applyAsDouble(i);
5274     }
5275 
5276     /**
5277      * Set all elements of the specified array, in parallel, using the
5278      * provided generator function to compute each element.
5279      *
5280      * <p>If the generator function throws an exception, an unchecked exception
5281      * is thrown from {@code parallelSetAll} and the array is left in an
5282      * indeterminate state.
5283      *
5284      * @apiNote
5285      * Setting a subrange of an array, in parallel, using a generator function
5286      * to compute each element, can be written as follows:
5287      * <pre>{@code
5288      * IntStream.range(startInclusive, endExclusive)
5289      *          .parallel()
5290      *          .forEach(i -> array[i] = generator.applyAsDouble(i));
5291      * }</pre>
5292      *
5293      * @param array array to be initialized
5294      * @param generator a function accepting an index and producing the desired
5295      *        value for that position
5296      * @throws NullPointerException if the generator is null
5297      * @since 1.8
5298      */
5299     public static void parallelSetAll(double[] array, IntToDoubleFunction generator) {
5300         Objects.requireNonNull(generator);
5301         IntStream.range(0, array.length).parallel().forEach(i -> { array[i] = generator.applyAsDouble(i); });
5302     }
5303 
5304     /**
5305      * Returns a {@link Spliterator} covering all of the specified array.
5306      *
5307      * <p>The spliterator reports {@link Spliterator#SIZED},
5308      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5309      * {@link Spliterator#IMMUTABLE}.
5310      *
5311      * @param <T> type of elements
5312      * @param array the array, assumed to be unmodified during use
5313      * @return a spliterator for the array elements
5314      * @since 1.8
5315      */
5316     public static <T> Spliterator<T> spliterator(T[] array) {
5317         return Spliterators.spliterator(array,
5318                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5319     }
5320 
5321     /**
5322      * Returns a {@link Spliterator} covering the specified range of the
5323      * specified array.
5324      *
5325      * <p>The spliterator reports {@link Spliterator#SIZED},
5326      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5327      * {@link Spliterator#IMMUTABLE}.
5328      *
5329      * @param <T> type of elements
5330      * @param array the array, assumed to be unmodified during use
5331      * @param startInclusive the first index to cover, inclusive
5332      * @param endExclusive index immediately past the last index to cover
5333      * @return a spliterator for the array elements
5334      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5335      *         negative, {@code endExclusive} is less than
5336      *         {@code startInclusive}, or {@code endExclusive} is greater than
5337      *         the array size
5338      * @since 1.8
5339      */
5340     public static <T> Spliterator<T> spliterator(T[] array, int startInclusive, int endExclusive) {
5341         return Spliterators.spliterator(array, startInclusive, endExclusive,
5342                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5343     }
5344 
5345     /**
5346      * Returns a {@link Spliterator.OfInt} covering all of the specified array.
5347      *
5348      * <p>The spliterator reports {@link Spliterator#SIZED},
5349      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5350      * {@link Spliterator#IMMUTABLE}.
5351      *
5352      * @param array the array, assumed to be unmodified during use
5353      * @return a spliterator for the array elements
5354      * @since 1.8
5355      */
5356     public static Spliterator.OfInt spliterator(int[] array) {
5357         return Spliterators.spliterator(array,
5358                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5359     }
5360 
5361     /**
5362      * Returns a {@link Spliterator.OfInt} covering the specified range of the
5363      * specified array.
5364      *
5365      * <p>The spliterator reports {@link Spliterator#SIZED},
5366      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5367      * {@link Spliterator#IMMUTABLE}.
5368      *
5369      * @param array the array, assumed to be unmodified during use
5370      * @param startInclusive the first index to cover, inclusive
5371      * @param endExclusive index immediately past the last index to cover
5372      * @return a spliterator for the array elements
5373      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5374      *         negative, {@code endExclusive} is less than
5375      *         {@code startInclusive}, or {@code endExclusive} is greater than
5376      *         the array size
5377      * @since 1.8
5378      */
5379     public static Spliterator.OfInt spliterator(int[] array, int startInclusive, int endExclusive) {
5380         return Spliterators.spliterator(array, startInclusive, endExclusive,
5381                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5382     }
5383 
5384     /**
5385      * Returns a {@link Spliterator.OfLong} covering all of the specified array.
5386      *
5387      * <p>The spliterator reports {@link Spliterator#SIZED},
5388      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5389      * {@link Spliterator#IMMUTABLE}.
5390      *
5391      * @param array the array, assumed to be unmodified during use
5392      * @return the spliterator for the array elements
5393      * @since 1.8
5394      */
5395     public static Spliterator.OfLong spliterator(long[] array) {
5396         return Spliterators.spliterator(array,
5397                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5398     }
5399 
5400     /**
5401      * Returns a {@link Spliterator.OfLong} covering the specified range of the
5402      * specified array.
5403      *
5404      * <p>The spliterator reports {@link Spliterator#SIZED},
5405      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5406      * {@link Spliterator#IMMUTABLE}.
5407      *
5408      * @param array the array, assumed to be unmodified during use
5409      * @param startInclusive the first index to cover, inclusive
5410      * @param endExclusive index immediately past the last index to cover
5411      * @return a spliterator for the array elements
5412      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5413      *         negative, {@code endExclusive} is less than
5414      *         {@code startInclusive}, or {@code endExclusive} is greater than
5415      *         the array size
5416      * @since 1.8
5417      */
5418     public static Spliterator.OfLong spliterator(long[] array, int startInclusive, int endExclusive) {
5419         return Spliterators.spliterator(array, startInclusive, endExclusive,
5420                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5421     }
5422 
5423     /**
5424      * Returns a {@link Spliterator.OfDouble} covering all of the specified
5425      * array.
5426      *
5427      * <p>The spliterator reports {@link Spliterator#SIZED},
5428      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5429      * {@link Spliterator#IMMUTABLE}.
5430      *
5431      * @param array the array, assumed to be unmodified during use
5432      * @return a spliterator for the array elements
5433      * @since 1.8
5434      */
5435     public static Spliterator.OfDouble spliterator(double[] array) {
5436         return Spliterators.spliterator(array,
5437                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5438     }
5439 
5440     /**
5441      * Returns a {@link Spliterator.OfDouble} covering the specified range of
5442      * the specified array.
5443      *
5444      * <p>The spliterator reports {@link Spliterator#SIZED},
5445      * {@link Spliterator#SUBSIZED}, {@link Spliterator#ORDERED}, and
5446      * {@link Spliterator#IMMUTABLE}.
5447      *
5448      * @param array the array, assumed to be unmodified during use
5449      * @param startInclusive the first index to cover, inclusive
5450      * @param endExclusive index immediately past the last index to cover
5451      * @return a spliterator for the array elements
5452      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5453      *         negative, {@code endExclusive} is less than
5454      *         {@code startInclusive}, or {@code endExclusive} is greater than
5455      *         the array size
5456      * @since 1.8
5457      */
5458     public static Spliterator.OfDouble spliterator(double[] array, int startInclusive, int endExclusive) {
5459         return Spliterators.spliterator(array, startInclusive, endExclusive,
5460                                         Spliterator.ORDERED | Spliterator.IMMUTABLE);
5461     }
5462 
5463     /**
5464      * Returns a sequential {@link Stream} with the specified array as its
5465      * source.
5466      *
5467      * @param <T> The type of the array elements
5468      * @param array The array, assumed to be unmodified during use
5469      * @return a {@code Stream} for the array
5470      * @since 1.8
5471      */
5472     public static <T> Stream<T> stream(T[] array) {
5473         return stream(array, 0, array.length);
5474     }
5475 
5476     /**
5477      * Returns a sequential {@link Stream} with the specified range of the
5478      * specified array as its source.
5479      *
5480      * @param <T> the type of the array elements
5481      * @param array the array, assumed to be unmodified during use
5482      * @param startInclusive the first index to cover, inclusive
5483      * @param endExclusive index immediately past the last index to cover
5484      * @return a {@code Stream} for the array range
5485      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5486      *         negative, {@code endExclusive} is less than
5487      *         {@code startInclusive}, or {@code endExclusive} is greater than
5488      *         the array size
5489      * @since 1.8
5490      */
5491     public static <T> Stream<T> stream(T[] array, int startInclusive, int endExclusive) {
5492         return StreamSupport.stream(spliterator(array, startInclusive, endExclusive), false);
5493     }
5494 
5495     /**
5496      * Returns a sequential {@link IntStream} with the specified array as its
5497      * source.
5498      *
5499      * @param array the array, assumed to be unmodified during use
5500      * @return an {@code IntStream} for the array
5501      * @since 1.8
5502      */
5503     public static IntStream stream(int[] array) {
5504         return stream(array, 0, array.length);
5505     }
5506 
5507     /**
5508      * Returns a sequential {@link IntStream} with the specified range of the
5509      * specified array as its source.
5510      *
5511      * @param array the array, assumed to be unmodified during use
5512      * @param startInclusive the first index to cover, inclusive
5513      * @param endExclusive index immediately past the last index to cover
5514      * @return an {@code IntStream} for the array range
5515      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5516      *         negative, {@code endExclusive} is less than
5517      *         {@code startInclusive}, or {@code endExclusive} is greater than
5518      *         the array size
5519      * @since 1.8
5520      */
5521     public static IntStream stream(int[] array, int startInclusive, int endExclusive) {
5522         return StreamSupport.intStream(spliterator(array, startInclusive, endExclusive), false);
5523     }
5524 
5525     /**
5526      * Returns a sequential {@link LongStream} with the specified array as its
5527      * source.
5528      *
5529      * @param array the array, assumed to be unmodified during use
5530      * @return a {@code LongStream} for the array
5531      * @since 1.8
5532      */
5533     public static LongStream stream(long[] array) {
5534         return stream(array, 0, array.length);
5535     }
5536 
5537     /**
5538      * Returns a sequential {@link LongStream} with the specified range of the
5539      * specified array as its source.
5540      *
5541      * @param array the array, assumed to be unmodified during use
5542      * @param startInclusive the first index to cover, inclusive
5543      * @param endExclusive index immediately past the last index to cover
5544      * @return a {@code LongStream} for the array range
5545      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5546      *         negative, {@code endExclusive} is less than
5547      *         {@code startInclusive}, or {@code endExclusive} is greater than
5548      *         the array size
5549      * @since 1.8
5550      */
5551     public static LongStream stream(long[] array, int startInclusive, int endExclusive) {
5552         return StreamSupport.longStream(spliterator(array, startInclusive, endExclusive), false);
5553     }
5554 
5555     /**
5556      * Returns a sequential {@link DoubleStream} with the specified array as its
5557      * source.
5558      *
5559      * @param array the array, assumed to be unmodified during use
5560      * @return a {@code DoubleStream} for the array
5561      * @since 1.8
5562      */
5563     public static DoubleStream stream(double[] array) {
5564         return stream(array, 0, array.length);
5565     }
5566 
5567     /**
5568      * Returns a sequential {@link DoubleStream} with the specified range of the
5569      * specified array as its source.
5570      *
5571      * @param array the array, assumed to be unmodified during use
5572      * @param startInclusive the first index to cover, inclusive
5573      * @param endExclusive index immediately past the last index to cover
5574      * @return a {@code DoubleStream} for the array range
5575      * @throws ArrayIndexOutOfBoundsException if {@code startInclusive} is
5576      *         negative, {@code endExclusive} is less than
5577      *         {@code startInclusive}, or {@code endExclusive} is greater than
5578      *         the array size
5579      * @since 1.8
5580      */
5581     public static DoubleStream stream(double[] array, int startInclusive, int endExclusive) {
5582         return StreamSupport.doubleStream(spliterator(array, startInclusive, endExclusive), false);
5583     }
5584 
5585 
5586     // Comparison methods
5587 
5588     // Compare boolean
5589 
5590     /**
5591      * Compares two {@code boolean} arrays lexicographically.
5592      *
5593      * <p>If the two arrays share a common prefix then the lexicographic
5594      * comparison is the result of comparing two elements, as if by
5595      * {@link Boolean#compare(boolean, boolean)}, at an index within the
5596      * respective arrays that is the prefix length.
5597      * Otherwise, one array is a proper prefix of the other and, lexicographic
5598      * comparison is the result of comparing the two array lengths.
5599      * (See {@link #mismatch(boolean[], boolean[])} for the definition of a
5600      * common and proper prefix.)
5601      *
5602      * <p>A {@code null} array reference is considered lexicographically less
5603      * than a non-{@code null} array reference.  Two {@code null} array
5604      * references are considered equal.
5605      *
5606      * <p>The comparison is consistent with {@link #equals(boolean[], boolean[]) equals},
5607      * more specifically the following holds for arrays {@code a} and {@code b}:
5608      * <pre>{@code
5609      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
5610      * }</pre>
5611      *
5612      * @apiNote
5613      * <p>This method behaves as if (for non-{@code null} array references):
5614      * <pre>{@code
5615      *     int i = Arrays.mismatch(a, b);
5616      *     if (i >= 0 && i < Math.min(a.length, b.length))
5617      *         return Boolean.compare(a[i], b[i]);
5618      *     return a.length - b.length;
5619      * }</pre>
5620      *
5621      * @param a the first array to compare
5622      * @param b the second array to compare
5623      * @return the value {@code 0} if the first and second array are equal and
5624      *         contain the same elements in the same order;
5625      *         a value less than {@code 0} if the first array is
5626      *         lexicographically less than the second array; and
5627      *         a value greater than {@code 0} if the first array is
5628      *         lexicographically greater than the second array
5629      * @since 9
5630      */
5631     public static int compare(boolean[] a, boolean[] b) {
5632         if (a == b)
5633             return 0;
5634         if (a == null || b == null)
5635             return a == null ? -1 : 1;
5636 
5637         int i = ArraysSupport.mismatch(a, b,
5638                                        Math.min(a.length, b.length));
5639         if (i >= 0) {
5640             return Boolean.compare(a[i], b[i]);
5641         }
5642 
5643         return a.length - b.length;
5644     }
5645 
5646     /**
5647      * Compares two {@code boolean} arrays lexicographically over the specified
5648      * ranges.
5649      *
5650      * <p>If the two arrays, over the specified ranges, share a common prefix
5651      * then the lexicographic comparison is the result of comparing two
5652      * elements, as if by {@link Boolean#compare(boolean, boolean)}, at a
5653      * relative index within the respective arrays that is the length of the
5654      * prefix.
5655      * Otherwise, one array is a proper prefix of the other and, lexicographic
5656      * comparison is the result of comparing the two range lengths.
5657      * (See {@link #mismatch(boolean[], int, int, boolean[], int, int)} for the
5658      * definition of a common and proper prefix.)
5659      *
5660      * <p>The comparison is consistent with
5661      * {@link #equals(boolean[], int, int, boolean[], int, int) equals}, more
5662      * specifically the following holds for arrays {@code a} and {@code b} with
5663      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
5664      * [{@code bFromIndex}, {@code bToIndex}) respectively:
5665      * <pre>{@code
5666      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
5667      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
5668      * }</pre>
5669      *
5670      * @apiNote
5671      * <p>This method behaves as if:
5672      * <pre>{@code
5673      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
5674      *                             b, bFromIndex, bToIndex);
5675      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
5676      *         return Boolean.compare(a[aFromIndex + i], b[bFromIndex + i]);
5677      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
5678      * }</pre>
5679      *
5680      * @param a the first array to compare
5681      * @param aFromIndex the index (inclusive) of the first element in the
5682      *                   first array to be compared
5683      * @param aToIndex the index (exclusive) of the last element in the
5684      *                 first array to be compared
5685      * @param b the second array to compare
5686      * @param bFromIndex the index (inclusive) of the first element in the
5687      *                   second array to be compared
5688      * @param bToIndex the index (exclusive) of the last element in the
5689      *                 second array to be compared
5690      * @return the value {@code 0} if, over the specified ranges, the first and
5691      *         second array are equal and contain the same elements in the same
5692      *         order;
5693      *         a value less than {@code 0} if, over the specified ranges, the
5694      *         first array is lexicographically less than the second array; and
5695      *         a value greater than {@code 0} if, over the specified ranges, the
5696      *         first array is lexicographically greater than the second array
5697      * @throws IllegalArgumentException
5698      *         if {@code aFromIndex > aToIndex} or
5699      *         if {@code bFromIndex > bToIndex}
5700      * @throws ArrayIndexOutOfBoundsException
5701      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
5702      *         if {@code bFromIndex < 0 or bToIndex > b.length}
5703      * @throws NullPointerException
5704      *         if either array is {@code null}
5705      * @since 9
5706      */
5707     public static int compare(boolean[] a, int aFromIndex, int aToIndex,
5708                               boolean[] b, int bFromIndex, int bToIndex) {
5709         rangeCheck(a.length, aFromIndex, aToIndex);
5710         rangeCheck(b.length, bFromIndex, bToIndex);
5711 
5712         int aLength = aToIndex - aFromIndex;
5713         int bLength = bToIndex - bFromIndex;
5714         int i = ArraysSupport.mismatch(a, aFromIndex,
5715                                        b, bFromIndex,
5716                                        Math.min(aLength, bLength));
5717         if (i >= 0) {
5718             return Boolean.compare(a[aFromIndex + i], b[bFromIndex + i]);
5719         }
5720 
5721         return aLength - bLength;
5722     }
5723 
5724     // Compare byte
5725 
5726     /**
5727      * Compares two {@code byte} arrays lexicographically.
5728      *
5729      * <p>If the two arrays share a common prefix then the lexicographic
5730      * comparison is the result of comparing two elements, as if by
5731      * {@link Byte#compare(byte, byte)}, at an index within the respective
5732      * arrays that is the prefix length.
5733      * Otherwise, one array is a proper prefix of the other and, lexicographic
5734      * comparison is the result of comparing the two array lengths.
5735      * (See {@link #mismatch(byte[], byte[])} for the definition of a common and
5736      * proper prefix.)
5737      *
5738      * <p>A {@code null} array reference is considered lexicographically less
5739      * than a non-{@code null} array reference.  Two {@code null} array
5740      * references are considered equal.
5741      *
5742      * <p>The comparison is consistent with {@link #equals(byte[], byte[]) equals},
5743      * more specifically the following holds for arrays {@code a} and {@code b}:
5744      * <pre>{@code
5745      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
5746      * }</pre>
5747      *
5748      * @apiNote
5749      * <p>This method behaves as if (for non-{@code null} array references):
5750      * <pre>{@code
5751      *     int i = Arrays.mismatch(a, b);
5752      *     if (i >= 0 && i < Math.min(a.length, b.length))
5753      *         return Byte.compare(a[i], b[i]);
5754      *     return a.length - b.length;
5755      * }</pre>
5756      *
5757      * @param a the first array to compare
5758      * @param b the second array to compare
5759      * @return the value {@code 0} if the first and second array are equal and
5760      *         contain the same elements in the same order;
5761      *         a value less than {@code 0} if the first array is
5762      *         lexicographically less than the second array; and
5763      *         a value greater than {@code 0} if the first array is
5764      *         lexicographically greater than the second array
5765      * @since 9
5766      */
5767     public static int compare(byte[] a, byte[] b) {
5768         if (a == b)
5769             return 0;
5770         if (a == null || b == null)
5771             return a == null ? -1 : 1;
5772 
5773         int i = ArraysSupport.mismatch(a, b,
5774                                        Math.min(a.length, b.length));
5775         if (i >= 0) {
5776             return Byte.compare(a[i], b[i]);
5777         }
5778 
5779         return a.length - b.length;
5780     }
5781 
5782     /**
5783      * Compares two {@code byte} arrays lexicographically over the specified
5784      * ranges.
5785      *
5786      * <p>If the two arrays, over the specified ranges, share a common prefix
5787      * then the lexicographic comparison is the result of comparing two
5788      * elements, as if by {@link Byte#compare(byte, byte)}, at a relative index
5789      * within the respective arrays that is the length of the prefix.
5790      * Otherwise, one array is a proper prefix of the other and, lexicographic
5791      * comparison is the result of comparing the two range lengths.
5792      * (See {@link #mismatch(byte[], int, int, byte[], int, int)} for the
5793      * definition of a common and proper prefix.)
5794      *
5795      * <p>The comparison is consistent with
5796      * {@link #equals(byte[], int, int, byte[], int, int) equals}, more
5797      * specifically the following holds for arrays {@code a} and {@code b} with
5798      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
5799      * [{@code bFromIndex}, {@code bToIndex}) respectively:
5800      * <pre>{@code
5801      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
5802      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
5803      * }</pre>
5804      *
5805      * @apiNote
5806      * <p>This method behaves as if:
5807      * <pre>{@code
5808      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
5809      *                             b, bFromIndex, bToIndex);
5810      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
5811      *         return Byte.compare(a[aFromIndex + i], b[bFromIndex + i]);
5812      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
5813      * }</pre>
5814      *
5815      * @param a the first array to compare
5816      * @param aFromIndex the index (inclusive) of the first element in the
5817      *                   first array to be compared
5818      * @param aToIndex the index (exclusive) of the last element in the
5819      *                 first array to be compared
5820      * @param b the second array to compare
5821      * @param bFromIndex the index (inclusive) of the first element in the
5822      *                   second array to be compared
5823      * @param bToIndex the index (exclusive) of the last element in the
5824      *                 second array to be compared
5825      * @return the value {@code 0} if, over the specified ranges, the first and
5826      *         second array are equal and contain the same elements in the same
5827      *         order;
5828      *         a value less than {@code 0} if, over the specified ranges, the
5829      *         first array is lexicographically less than the second array; and
5830      *         a value greater than {@code 0} if, over the specified ranges, the
5831      *         first array is lexicographically greater than the second array
5832      * @throws IllegalArgumentException
5833      *         if {@code aFromIndex > aToIndex} or
5834      *         if {@code bFromIndex > bToIndex}
5835      * @throws ArrayIndexOutOfBoundsException
5836      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
5837      *         if {@code bFromIndex < 0 or bToIndex > b.length}
5838      * @throws NullPointerException
5839      *         if either array is {@code null}
5840      * @since 9
5841      */
5842     public static int compare(byte[] a, int aFromIndex, int aToIndex,
5843                               byte[] b, int bFromIndex, int bToIndex) {
5844         rangeCheck(a.length, aFromIndex, aToIndex);
5845         rangeCheck(b.length, bFromIndex, bToIndex);
5846 
5847         int aLength = aToIndex - aFromIndex;
5848         int bLength = bToIndex - bFromIndex;
5849         int i = ArraysSupport.mismatch(a, aFromIndex,
5850                                        b, bFromIndex,
5851                                        Math.min(aLength, bLength));
5852         if (i >= 0) {
5853             return Byte.compare(a[aFromIndex + i], b[bFromIndex + i]);
5854         }
5855 
5856         return aLength - bLength;
5857     }
5858 
5859     /**
5860      * Compares two {@code byte} arrays lexicographically, numerically treating
5861      * elements as unsigned.
5862      *
5863      * <p>If the two arrays share a common prefix then the lexicographic
5864      * comparison is the result of comparing two elements, as if by
5865      * {@link Byte#compareUnsigned(byte, byte)}, at an index within the
5866      * respective arrays that is the prefix length.
5867      * Otherwise, one array is a proper prefix of the other and, lexicographic
5868      * comparison is the result of comparing the two array lengths.
5869      * (See {@link #mismatch(byte[], byte[])} for the definition of a common
5870      * and proper prefix.)
5871      *
5872      * <p>A {@code null} array reference is considered lexicographically less
5873      * than a non-{@code null} array reference.  Two {@code null} array
5874      * references are considered equal.
5875      *
5876      * @apiNote
5877      * <p>This method behaves as if (for non-{@code null} array references):
5878      * <pre>{@code
5879      *     int i = Arrays.mismatch(a, b);
5880      *     if (i >= 0 && i < Math.min(a.length, b.length))
5881      *         return Byte.compareUnsigned(a[i], b[i]);
5882      *     return a.length - b.length;
5883      * }</pre>
5884      *
5885      * @param a the first array to compare
5886      * @param b the second array to compare
5887      * @return the value {@code 0} if the first and second array are
5888      *         equal and contain the same elements in the same order;
5889      *         a value less than {@code 0} if the first array is
5890      *         lexicographically less than the second array; and
5891      *         a value greater than {@code 0} if the first array is
5892      *         lexicographically greater than the second array
5893      * @since 9
5894      */
5895     public static int compareUnsigned(byte[] a, byte[] b) {
5896         if (a == b)
5897             return 0;
5898         if (a == null || b == null)
5899             return a == null ? -1 : 1;
5900 
5901         int i = ArraysSupport.mismatch(a, b,
5902                                        Math.min(a.length, b.length));
5903         if (i >= 0) {
5904             return Byte.compareUnsigned(a[i], b[i]);
5905         }
5906 
5907         return a.length - b.length;
5908     }
5909 
5910 
5911     /**
5912      * Compares two {@code byte} arrays lexicographically over the specified
5913      * ranges, numerically treating elements as unsigned.
5914      *
5915      * <p>If the two arrays, over the specified ranges, share a common prefix
5916      * then the lexicographic comparison is the result of comparing two
5917      * elements, as if by {@link Byte#compareUnsigned(byte, byte)}, at a
5918      * relative index within the respective arrays that is the length of the
5919      * prefix.
5920      * Otherwise, one array is a proper prefix of the other and, lexicographic
5921      * comparison is the result of comparing the two range lengths.
5922      * (See {@link #mismatch(byte[], int, int, byte[], int, int)} for the
5923      * definition of a common and proper prefix.)
5924      *
5925      * @apiNote
5926      * <p>This method behaves as if:
5927      * <pre>{@code
5928      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
5929      *                             b, bFromIndex, bToIndex);
5930      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
5931      *         return Byte.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
5932      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
5933      * }</pre>
5934      *
5935      * @param a the first array to compare
5936      * @param aFromIndex the index (inclusive) of the first element in the
5937      *                   first array to be compared
5938      * @param aToIndex the index (exclusive) of the last element in the
5939      *                 first array to be compared
5940      * @param b the second array to compare
5941      * @param bFromIndex the index (inclusive) of the first element in the
5942      *                   second array to be compared
5943      * @param bToIndex the index (exclusive) of the last element in the
5944      *                 second array to be compared
5945      * @return the value {@code 0} if, over the specified ranges, the first and
5946      *         second array are equal and contain the same elements in the same
5947      *         order;
5948      *         a value less than {@code 0} if, over the specified ranges, the
5949      *         first array is lexicographically less than the second array; and
5950      *         a value greater than {@code 0} if, over the specified ranges, the
5951      *         first array is lexicographically greater than the second array
5952      * @throws IllegalArgumentException
5953      *         if {@code aFromIndex > aToIndex} or
5954      *         if {@code bFromIndex > bToIndex}
5955      * @throws ArrayIndexOutOfBoundsException
5956      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
5957      *         if {@code bFromIndex < 0 or bToIndex > b.length}
5958      * @throws NullPointerException
5959      *         if either array is null
5960      * @since 9
5961      */
5962     public static int compareUnsigned(byte[] a, int aFromIndex, int aToIndex,
5963                                       byte[] b, int bFromIndex, int bToIndex) {
5964         rangeCheck(a.length, aFromIndex, aToIndex);
5965         rangeCheck(b.length, bFromIndex, bToIndex);
5966 
5967         int aLength = aToIndex - aFromIndex;
5968         int bLength = bToIndex - bFromIndex;
5969         int i = ArraysSupport.mismatch(a, aFromIndex,
5970                                        b, bFromIndex,
5971                                        Math.min(aLength, bLength));
5972         if (i >= 0) {
5973             return Byte.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
5974         }
5975 
5976         return aLength - bLength;
5977     }
5978 
5979     // Compare short
5980 
5981     /**
5982      * Compares two {@code short} arrays lexicographically.
5983      *
5984      * <p>If the two arrays share a common prefix then the lexicographic
5985      * comparison is the result of comparing two elements, as if by
5986      * {@link Short#compare(short, short)}, at an index within the respective
5987      * arrays that is the prefix length.
5988      * Otherwise, one array is a proper prefix of the other and, lexicographic
5989      * comparison is the result of comparing the two array lengths.
5990      * (See {@link #mismatch(short[], short[])} for the definition of a common
5991      * and proper prefix.)
5992      *
5993      * <p>A {@code null} array reference is considered lexicographically less
5994      * than a non-{@code null} array reference.  Two {@code null} array
5995      * references are considered equal.
5996      *
5997      * <p>The comparison is consistent with {@link #equals(short[], short[]) equals},
5998      * more specifically the following holds for arrays {@code a} and {@code b}:
5999      * <pre>{@code
6000      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
6001      * }</pre>
6002      *
6003      * @apiNote
6004      * <p>This method behaves as if (for non-{@code null} array references):
6005      * <pre>{@code
6006      *     int i = Arrays.mismatch(a, b);
6007      *     if (i >= 0 && i < Math.min(a.length, b.length))
6008      *         return Short.compare(a[i], b[i]);
6009      *     return a.length - b.length;
6010      * }</pre>
6011      *
6012      * @param a the first array to compare
6013      * @param b the second array to compare
6014      * @return the value {@code 0} if the first and second array are equal and
6015      *         contain the same elements in the same order;
6016      *         a value less than {@code 0} if the first array is
6017      *         lexicographically less than the second array; and
6018      *         a value greater than {@code 0} if the first array is
6019      *         lexicographically greater than the second array
6020      * @since 9
6021      */
6022     public static int compare(short[] a, short[] b) {
6023         if (a == b)
6024             return 0;
6025         if (a == null || b == null)
6026             return a == null ? -1 : 1;
6027 
6028         int i = ArraysSupport.mismatch(a, b,
6029                                        Math.min(a.length, b.length));
6030         if (i >= 0) {
6031             return Short.compare(a[i], b[i]);
6032         }
6033 
6034         return a.length - b.length;
6035     }
6036 
6037     /**
6038      * Compares two {@code short} arrays lexicographically over the specified
6039      * ranges.
6040      *
6041      * <p>If the two arrays, over the specified ranges, share a common prefix
6042      * then the lexicographic comparison is the result of comparing two
6043      * elements, as if by {@link Short#compare(short, short)}, at a relative
6044      * index within the respective arrays that is the length of the prefix.
6045      * Otherwise, one array is a proper prefix of the other and, lexicographic
6046      * comparison is the result of comparing the two range lengths.
6047      * (See {@link #mismatch(short[], int, int, short[], int, int)} for the
6048      * definition of a common and proper prefix.)
6049      *
6050      * <p>The comparison is consistent with
6051      * {@link #equals(short[], int, int, short[], int, int) equals}, more
6052      * specifically the following holds for arrays {@code a} and {@code b} with
6053      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
6054      * [{@code bFromIndex}, {@code bToIndex}) respectively:
6055      * <pre>{@code
6056      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
6057      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
6058      * }</pre>
6059      *
6060      * @apiNote
6061      * <p>This method behaves as if:
6062      * <pre>{@code
6063      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6064      *                             b, bFromIndex, bToIndex);
6065      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6066      *         return Short.compare(a[aFromIndex + i], b[bFromIndex + i]);
6067      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6068      * }</pre>
6069      *
6070      * @param a the first array to compare
6071      * @param aFromIndex the index (inclusive) of the first element in the
6072      *                   first array to be compared
6073      * @param aToIndex the index (exclusive) of the last element in the
6074      *                 first array to be compared
6075      * @param b the second array to compare
6076      * @param bFromIndex the index (inclusive) of the first element in the
6077      *                   second array to be compared
6078      * @param bToIndex the index (exclusive) of the last element in the
6079      *                 second array to be compared
6080      * @return the value {@code 0} if, over the specified ranges, the first and
6081      *         second array are equal and contain the same elements in the same
6082      *         order;
6083      *         a value less than {@code 0} if, over the specified ranges, the
6084      *         first array is lexicographically less than the second array; and
6085      *         a value greater than {@code 0} if, over the specified ranges, the
6086      *         first array is lexicographically greater than the second array
6087      * @throws IllegalArgumentException
6088      *         if {@code aFromIndex > aToIndex} or
6089      *         if {@code bFromIndex > bToIndex}
6090      * @throws ArrayIndexOutOfBoundsException
6091      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6092      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6093      * @throws NullPointerException
6094      *         if either array is {@code null}
6095      * @since 9
6096      */
6097     public static int compare(short[] a, int aFromIndex, int aToIndex,
6098                               short[] b, int bFromIndex, int bToIndex) {
6099         rangeCheck(a.length, aFromIndex, aToIndex);
6100         rangeCheck(b.length, bFromIndex, bToIndex);
6101 
6102         int aLength = aToIndex - aFromIndex;
6103         int bLength = bToIndex - bFromIndex;
6104         int i = ArraysSupport.mismatch(a, aFromIndex,
6105                                        b, bFromIndex,
6106                                        Math.min(aLength, bLength));
6107         if (i >= 0) {
6108             return Short.compare(a[aFromIndex + i], b[bFromIndex + i]);
6109         }
6110 
6111         return aLength - bLength;
6112     }
6113 
6114     /**
6115      * Compares two {@code short} arrays lexicographically, numerically treating
6116      * elements as unsigned.
6117      *
6118      * <p>If the two arrays share a common prefix then the lexicographic
6119      * comparison is the result of comparing two elements, as if by
6120      * {@link Short#compareUnsigned(short, short)}, at an index within the
6121      * respective arrays that is the prefix length.
6122      * Otherwise, one array is a proper prefix of the other and, lexicographic
6123      * comparison is the result of comparing the two array lengths.
6124      * (See {@link #mismatch(short[], short[])} for the definition of a common
6125      * and proper prefix.)
6126      *
6127      * <p>A {@code null} array reference is considered lexicographically less
6128      * than a non-{@code null} array reference.  Two {@code null} array
6129      * references are considered equal.
6130      *
6131      * @apiNote
6132      * <p>This method behaves as if (for non-{@code null} array references):
6133      * <pre>{@code
6134      *     int i = Arrays.mismatch(a, b);
6135      *     if (i >= 0 && i < Math.min(a.length, b.length))
6136      *         return Short.compareUnsigned(a[i], b[i]);
6137      *     return a.length - b.length;
6138      * }</pre>
6139      *
6140      * @param a the first array to compare
6141      * @param b the second array to compare
6142      * @return the value {@code 0} if the first and second array are
6143      *         equal and contain the same elements in the same order;
6144      *         a value less than {@code 0} if the first array is
6145      *         lexicographically less than the second array; and
6146      *         a value greater than {@code 0} if the first array is
6147      *         lexicographically greater than the second array
6148      * @since 9
6149      */
6150     public static int compareUnsigned(short[] a, short[] b) {
6151         if (a == b)
6152             return 0;
6153         if (a == null || b == null)
6154             return a == null ? -1 : 1;
6155 
6156         int i = ArraysSupport.mismatch(a, b,
6157                                        Math.min(a.length, b.length));
6158         if (i >= 0) {
6159             return Short.compareUnsigned(a[i], b[i]);
6160         }
6161 
6162         return a.length - b.length;
6163     }
6164 
6165     /**
6166      * Compares two {@code short} arrays lexicographically over the specified
6167      * ranges, numerically treating elements as unsigned.
6168      *
6169      * <p>If the two arrays, over the specified ranges, share a common prefix
6170      * then the lexicographic comparison is the result of comparing two
6171      * elements, as if by {@link Short#compareUnsigned(short, short)}, at a
6172      * relative index within the respective arrays that is the length of the
6173      * prefix.
6174      * Otherwise, one array is a proper prefix of the other and, lexicographic
6175      * comparison is the result of comparing the two range lengths.
6176      * (See {@link #mismatch(short[], int, int, short[], int, int)} for the
6177      * definition of a common and proper prefix.)
6178      *
6179      * @apiNote
6180      * <p>This method behaves as if:
6181      * <pre>{@code
6182      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6183      *                             b, bFromIndex, bToIndex);
6184      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6185      *         return Short.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
6186      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6187      * }</pre>
6188      *
6189      * @param a the first array to compare
6190      * @param aFromIndex the index (inclusive) of the first element in the
6191      *                   first array to be compared
6192      * @param aToIndex the index (exclusive) of the last element in the
6193      *                 first array to be compared
6194      * @param b the second array to compare
6195      * @param bFromIndex the index (inclusive) of the first element in the
6196      *                   second array to be compared
6197      * @param bToIndex the index (exclusive) of the last element in the
6198      *                 second array to be compared
6199      * @return the value {@code 0} if, over the specified ranges, the first and
6200      *         second array are equal and contain the same elements in the same
6201      *         order;
6202      *         a value less than {@code 0} if, over the specified ranges, the
6203      *         first array is lexicographically less than the second array; and
6204      *         a value greater than {@code 0} if, over the specified ranges, the
6205      *         first array is lexicographically greater than the second array
6206      * @throws IllegalArgumentException
6207      *         if {@code aFromIndex > aToIndex} or
6208      *         if {@code bFromIndex > bToIndex}
6209      * @throws ArrayIndexOutOfBoundsException
6210      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6211      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6212      * @throws NullPointerException
6213      *         if either array is null
6214      * @since 9
6215      */
6216     public static int compareUnsigned(short[] a, int aFromIndex, int aToIndex,
6217                                       short[] b, int bFromIndex, int bToIndex) {
6218         rangeCheck(a.length, aFromIndex, aToIndex);
6219         rangeCheck(b.length, bFromIndex, bToIndex);
6220 
6221         int aLength = aToIndex - aFromIndex;
6222         int bLength = bToIndex - bFromIndex;
6223         int i = ArraysSupport.mismatch(a, aFromIndex,
6224                                        b, bFromIndex,
6225                                        Math.min(aLength, bLength));
6226         if (i >= 0) {
6227             return Short.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
6228         }
6229 
6230         return aLength - bLength;
6231     }
6232 
6233     // Compare char
6234 
6235     /**
6236      * Compares two {@code char} arrays lexicographically.
6237      *
6238      * <p>If the two arrays share a common prefix then the lexicographic
6239      * comparison is the result of comparing two elements, as if by
6240      * {@link Character#compare(char, char)}, at an index within the respective
6241      * arrays that is the prefix length.
6242      * Otherwise, one array is a proper prefix of the other and, lexicographic
6243      * comparison is the result of comparing the two array lengths.
6244      * (See {@link #mismatch(char[], char[])} for the definition of a common and
6245      * proper prefix.)
6246      *
6247      * <p>A {@code null} array reference is considered lexicographically less
6248      * than a non-{@code null} array reference.  Two {@code null} array
6249      * references are considered equal.
6250      *
6251      * <p>The comparison is consistent with {@link #equals(char[], char[]) equals},
6252      * more specifically the following holds for arrays {@code a} and {@code b}:
6253      * <pre>{@code
6254      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
6255      * }</pre>
6256      *
6257      * @apiNote
6258      * <p>This method behaves as if (for non-{@code null} array references):
6259      * <pre>{@code
6260      *     int i = Arrays.mismatch(a, b);
6261      *     if (i >= 0 && i < Math.min(a.length, b.length))
6262      *         return Character.compare(a[i], b[i]);
6263      *     return a.length - b.length;
6264      * }</pre>
6265      *
6266      * @param a the first array to compare
6267      * @param b the second array to compare
6268      * @return the value {@code 0} if the first and second array are equal and
6269      *         contain the same elements in the same order;
6270      *         a value less than {@code 0} if the first array is
6271      *         lexicographically less than the second array; and
6272      *         a value greater than {@code 0} if the first array is
6273      *         lexicographically greater than the second array
6274      * @since 9
6275      */
6276     public static int compare(char[] a, char[] b) {
6277         if (a == b)
6278             return 0;
6279         if (a == null || b == null)
6280             return a == null ? -1 : 1;
6281 
6282         int i = ArraysSupport.mismatch(a, b,
6283                                        Math.min(a.length, b.length));
6284         if (i >= 0) {
6285             return Character.compare(a[i], b[i]);
6286         }
6287 
6288         return a.length - b.length;
6289     }
6290 
6291     /**
6292      * Compares two {@code char} arrays lexicographically over the specified
6293      * ranges.
6294      *
6295      * <p>If the two arrays, over the specified ranges, share a common prefix
6296      * then the lexicographic comparison is the result of comparing two
6297      * elements, as if by {@link Character#compare(char, char)}, at a relative
6298      * index within the respective arrays that is the length of the prefix.
6299      * Otherwise, one array is a proper prefix of the other and, lexicographic
6300      * comparison is the result of comparing the two range lengths.
6301      * (See {@link #mismatch(char[], int, int, char[], int, int)} for the
6302      * definition of a common and proper prefix.)
6303      *
6304      * <p>The comparison is consistent with
6305      * {@link #equals(char[], int, int, char[], int, int) equals}, more
6306      * specifically the following holds for arrays {@code a} and {@code b} with
6307      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
6308      * [{@code bFromIndex}, {@code bToIndex}) respectively:
6309      * <pre>{@code
6310      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
6311      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
6312      * }</pre>
6313      *
6314      * @apiNote
6315      * <p>This method behaves as if:
6316      * <pre>{@code
6317      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6318      *                             b, bFromIndex, bToIndex);
6319      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6320      *         return Character.compare(a[aFromIndex + i], b[bFromIndex + i]);
6321      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6322      * }</pre>
6323      *
6324      * @param a the first array to compare
6325      * @param aFromIndex the index (inclusive) of the first element in the
6326      *                   first array to be compared
6327      * @param aToIndex the index (exclusive) of the last element in the
6328      *                 first array to be compared
6329      * @param b the second array to compare
6330      * @param bFromIndex the index (inclusive) of the first element in the
6331      *                   second array to be compared
6332      * @param bToIndex the index (exclusive) of the last element in the
6333      *                 second array to be compared
6334      * @return the value {@code 0} if, over the specified ranges, the first and
6335      *         second array are equal and contain the same elements in the same
6336      *         order;
6337      *         a value less than {@code 0} if, over the specified ranges, the
6338      *         first array is lexicographically less than the second array; and
6339      *         a value greater than {@code 0} if, over the specified ranges, the
6340      *         first array is lexicographically greater than the second array
6341      * @throws IllegalArgumentException
6342      *         if {@code aFromIndex > aToIndex} or
6343      *         if {@code bFromIndex > bToIndex}
6344      * @throws ArrayIndexOutOfBoundsException
6345      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6346      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6347      * @throws NullPointerException
6348      *         if either array is {@code null}
6349      * @since 9
6350      */
6351     public static int compare(char[] a, int aFromIndex, int aToIndex,
6352                               char[] b, int bFromIndex, int bToIndex) {
6353         rangeCheck(a.length, aFromIndex, aToIndex);
6354         rangeCheck(b.length, bFromIndex, bToIndex);
6355 
6356         int aLength = aToIndex - aFromIndex;
6357         int bLength = bToIndex - bFromIndex;
6358         int i = ArraysSupport.mismatch(a, aFromIndex,
6359                                        b, bFromIndex,
6360                                        Math.min(aLength, bLength));
6361         if (i >= 0) {
6362             return Character.compare(a[aFromIndex + i], b[bFromIndex + i]);
6363         }
6364 
6365         return aLength - bLength;
6366     }
6367 
6368     // Compare int
6369 
6370     /**
6371      * Compares two {@code int} arrays lexicographically.
6372      *
6373      * <p>If the two arrays share a common prefix then the lexicographic
6374      * comparison is the result of comparing two elements, as if by
6375      * {@link Integer#compare(int, int)}, at an index within the respective
6376      * arrays that is the prefix length.
6377      * Otherwise, one array is a proper prefix of the other and, lexicographic
6378      * comparison is the result of comparing the two array lengths.
6379      * (See {@link #mismatch(int[], int[])} for the definition of a common and
6380      * proper prefix.)
6381      *
6382      * <p>A {@code null} array reference is considered lexicographically less
6383      * than a non-{@code null} array reference.  Two {@code null} array
6384      * references are considered equal.
6385      *
6386      * <p>The comparison is consistent with {@link #equals(int[], int[]) equals},
6387      * more specifically the following holds for arrays {@code a} and {@code b}:
6388      * <pre>{@code
6389      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
6390      * }</pre>
6391      *
6392      * @apiNote
6393      * <p>This method behaves as if (for non-{@code null} array references):
6394      * <pre>{@code
6395      *     int i = Arrays.mismatch(a, b);
6396      *     if (i >= 0 && i < Math.min(a.length, b.length))
6397      *         return Integer.compare(a[i], b[i]);
6398      *     return a.length - b.length;
6399      * }</pre>
6400      *
6401      * @param a the first array to compare
6402      * @param b the second array to compare
6403      * @return the value {@code 0} if the first and second array are equal and
6404      *         contain the same elements in the same order;
6405      *         a value less than {@code 0} if the first array is
6406      *         lexicographically less than the second array; and
6407      *         a value greater than {@code 0} if the first array is
6408      *         lexicographically greater than the second array
6409      * @since 9
6410      */
6411     public static int compare(int[] a, int[] b) {
6412         if (a == b)
6413             return 0;
6414         if (a == null || b == null)
6415             return a == null ? -1 : 1;
6416 
6417         int i = ArraysSupport.mismatch(a, b,
6418                                        Math.min(a.length, b.length));
6419         if (i >= 0) {
6420             return Integer.compare(a[i], b[i]);
6421         }
6422 
6423         return a.length - b.length;
6424     }
6425 
6426     /**
6427      * Compares two {@code int} arrays lexicographically over the specified
6428      * ranges.
6429      *
6430      * <p>If the two arrays, over the specified ranges, share a common prefix
6431      * then the lexicographic comparison is the result of comparing two
6432      * elements, as if by {@link Integer#compare(int, int)}, at a relative index
6433      * within the respective arrays that is the length of the prefix.
6434      * Otherwise, one array is a proper prefix of the other and, lexicographic
6435      * comparison is the result of comparing the two range lengths.
6436      * (See {@link #mismatch(int[], int, int, int[], int, int)} for the
6437      * definition of a common and proper prefix.)
6438      *
6439      * <p>The comparison is consistent with
6440      * {@link #equals(int[], int, int, int[], int, int) equals}, more
6441      * specifically the following holds for arrays {@code a} and {@code b} with
6442      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
6443      * [{@code bFromIndex}, {@code bToIndex}) respectively:
6444      * <pre>{@code
6445      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
6446      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
6447      * }</pre>
6448      *
6449      * @apiNote
6450      * <p>This method behaves as if:
6451      * <pre>{@code
6452      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6453      *                             b, bFromIndex, bToIndex);
6454      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6455      *         return Integer.compare(a[aFromIndex + i], b[bFromIndex + i]);
6456      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6457      * }</pre>
6458      *
6459      * @param a the first array to compare
6460      * @param aFromIndex the index (inclusive) of the first element in the
6461      *                   first array to be compared
6462      * @param aToIndex the index (exclusive) of the last element in the
6463      *                 first array to be compared
6464      * @param b the second array to compare
6465      * @param bFromIndex the index (inclusive) of the first element in the
6466      *                   second array to be compared
6467      * @param bToIndex the index (exclusive) of the last element in the
6468      *                 second array to be compared
6469      * @return the value {@code 0} if, over the specified ranges, the first and
6470      *         second array are equal and contain the same elements in the same
6471      *         order;
6472      *         a value less than {@code 0} if, over the specified ranges, the
6473      *         first array is lexicographically less than the second array; and
6474      *         a value greater than {@code 0} if, over the specified ranges, the
6475      *         first array is lexicographically greater than the second array
6476      * @throws IllegalArgumentException
6477      *         if {@code aFromIndex > aToIndex} or
6478      *         if {@code bFromIndex > bToIndex}
6479      * @throws ArrayIndexOutOfBoundsException
6480      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6481      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6482      * @throws NullPointerException
6483      *         if either array is {@code null}
6484      * @since 9
6485      */
6486     public static int compare(int[] a, int aFromIndex, int aToIndex,
6487                               int[] b, int bFromIndex, int bToIndex) {
6488         rangeCheck(a.length, aFromIndex, aToIndex);
6489         rangeCheck(b.length, bFromIndex, bToIndex);
6490 
6491         int aLength = aToIndex - aFromIndex;
6492         int bLength = bToIndex - bFromIndex;
6493         int i = ArraysSupport.mismatch(a, aFromIndex,
6494                                        b, bFromIndex,
6495                                        Math.min(aLength, bLength));
6496         if (i >= 0) {
6497             return Integer.compare(a[aFromIndex + i], b[bFromIndex + i]);
6498         }
6499 
6500         return aLength - bLength;
6501     }
6502 
6503     /**
6504      * Compares two {@code int} arrays lexicographically, numerically treating
6505      * elements as unsigned.
6506      *
6507      * <p>If the two arrays share a common prefix then the lexicographic
6508      * comparison is the result of comparing two elements, as if by
6509      * {@link Integer#compareUnsigned(int, int)}, at an index within the
6510      * respective arrays that is the prefix length.
6511      * Otherwise, one array is a proper prefix of the other and, lexicographic
6512      * comparison is the result of comparing the two array lengths.
6513      * (See {@link #mismatch(int[], int[])} for the definition of a common
6514      * and proper prefix.)
6515      *
6516      * <p>A {@code null} array reference is considered lexicographically less
6517      * than a non-{@code null} array reference.  Two {@code null} array
6518      * references are considered equal.
6519      *
6520      * @apiNote
6521      * <p>This method behaves as if (for non-{@code null} array references):
6522      * <pre>{@code
6523      *     int i = Arrays.mismatch(a, b);
6524      *     if (i >= 0 && i < Math.min(a.length, b.length))
6525      *         return Integer.compareUnsigned(a[i], b[i]);
6526      *     return a.length - b.length;
6527      * }</pre>
6528      *
6529      * @param a the first array to compare
6530      * @param b the second array to compare
6531      * @return the value {@code 0} if the first and second array are
6532      *         equal and contain the same elements in the same order;
6533      *         a value less than {@code 0} if the first array is
6534      *         lexicographically less than the second array; and
6535      *         a value greater than {@code 0} if the first array is
6536      *         lexicographically greater than the second array
6537      * @since 9
6538      */
6539     public static int compareUnsigned(int[] a, int[] b) {
6540         if (a == b)
6541             return 0;
6542         if (a == null || b == null)
6543             return a == null ? -1 : 1;
6544 
6545         int i = ArraysSupport.mismatch(a, b,
6546                                        Math.min(a.length, b.length));
6547         if (i >= 0) {
6548             return Integer.compareUnsigned(a[i], b[i]);
6549         }
6550 
6551         return a.length - b.length;
6552     }
6553 
6554     /**
6555      * Compares two {@code int} arrays lexicographically over the specified
6556      * ranges, numerically treating elements as unsigned.
6557      *
6558      * <p>If the two arrays, over the specified ranges, share a common prefix
6559      * then the lexicographic comparison is the result of comparing two
6560      * elements, as if by {@link Integer#compareUnsigned(int, int)}, at a
6561      * relative index within the respective arrays that is the length of the
6562      * prefix.
6563      * Otherwise, one array is a proper prefix of the other and, lexicographic
6564      * comparison is the result of comparing the two range lengths.
6565      * (See {@link #mismatch(int[], int, int, int[], int, int)} for the
6566      * definition of a common and proper prefix.)
6567      *
6568      * @apiNote
6569      * <p>This method behaves as if:
6570      * <pre>{@code
6571      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6572      *                             b, bFromIndex, bToIndex);
6573      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6574      *         return Integer.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
6575      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6576      * }</pre>
6577      *
6578      * @param a the first array to compare
6579      * @param aFromIndex the index (inclusive) of the first element in the
6580      *                   first array to be compared
6581      * @param aToIndex the index (exclusive) of the last element in the
6582      *                 first array to be compared
6583      * @param b the second array to compare
6584      * @param bFromIndex the index (inclusive) of the first element in the
6585      *                   second array to be compared
6586      * @param bToIndex the index (exclusive) of the last element in the
6587      *                 second array to be compared
6588      * @return the value {@code 0} if, over the specified ranges, the first and
6589      *         second array are equal and contain the same elements in the same
6590      *         order;
6591      *         a value less than {@code 0} if, over the specified ranges, the
6592      *         first array is lexicographically less than the second array; and
6593      *         a value greater than {@code 0} if, over the specified ranges, the
6594      *         first array is lexicographically greater than the second array
6595      * @throws IllegalArgumentException
6596      *         if {@code aFromIndex > aToIndex} or
6597      *         if {@code bFromIndex > bToIndex}
6598      * @throws ArrayIndexOutOfBoundsException
6599      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6600      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6601      * @throws NullPointerException
6602      *         if either array is null
6603      * @since 9
6604      */
6605     public static int compareUnsigned(int[] a, int aFromIndex, int aToIndex,
6606                                       int[] b, int bFromIndex, int bToIndex) {
6607         rangeCheck(a.length, aFromIndex, aToIndex);
6608         rangeCheck(b.length, bFromIndex, bToIndex);
6609 
6610         int aLength = aToIndex - aFromIndex;
6611         int bLength = bToIndex - bFromIndex;
6612         int i = ArraysSupport.mismatch(a, aFromIndex,
6613                                        b, bFromIndex,
6614                                        Math.min(aLength, bLength));
6615         if (i >= 0) {
6616             return Integer.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
6617         }
6618 
6619         return aLength - bLength;
6620     }
6621 
6622     // Compare long
6623 
6624     /**
6625      * Compares two {@code long} arrays lexicographically.
6626      *
6627      * <p>If the two arrays share a common prefix then the lexicographic
6628      * comparison is the result of comparing two elements, as if by
6629      * {@link Long#compare(long, long)}, at an index within the respective
6630      * arrays that is the prefix length.
6631      * Otherwise, one array is a proper prefix of the other and, lexicographic
6632      * comparison is the result of comparing the two array lengths.
6633      * (See {@link #mismatch(long[], long[])} for the definition of a common and
6634      * proper prefix.)
6635      *
6636      * <p>A {@code null} array reference is considered lexicographically less
6637      * than a non-{@code null} array reference.  Two {@code null} array
6638      * references are considered equal.
6639      *
6640      * <p>The comparison is consistent with {@link #equals(long[], long[]) equals},
6641      * more specifically the following holds for arrays {@code a} and {@code b}:
6642      * <pre>{@code
6643      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
6644      * }</pre>
6645      *
6646      * @apiNote
6647      * <p>This method behaves as if (for non-{@code null} array references):
6648      * <pre>{@code
6649      *     int i = Arrays.mismatch(a, b);
6650      *     if (i >= 0 && i < Math.min(a.length, b.length))
6651      *         return Long.compare(a[i], b[i]);
6652      *     return a.length - b.length;
6653      * }</pre>
6654      *
6655      * @param a the first array to compare
6656      * @param b the second array to compare
6657      * @return the value {@code 0} if the first and second array are equal and
6658      *         contain the same elements in the same order;
6659      *         a value less than {@code 0} if the first array is
6660      *         lexicographically less than the second array; and
6661      *         a value greater than {@code 0} if the first array is
6662      *         lexicographically greater than the second array
6663      * @since 9
6664      */
6665     public static int compare(long[] a, long[] b) {
6666         if (a == b)
6667             return 0;
6668         if (a == null || b == null)
6669             return a == null ? -1 : 1;
6670 
6671         int i = ArraysSupport.mismatch(a, b,
6672                                        Math.min(a.length, b.length));
6673         if (i >= 0) {
6674             return Long.compare(a[i], b[i]);
6675         }
6676 
6677         return a.length - b.length;
6678     }
6679 
6680     /**
6681      * Compares two {@code long} arrays lexicographically over the specified
6682      * ranges.
6683      *
6684      * <p>If the two arrays, over the specified ranges, share a common prefix
6685      * then the lexicographic comparison is the result of comparing two
6686      * elements, as if by {@link Long#compare(long, long)}, at a relative index
6687      * within the respective arrays that is the length of the prefix.
6688      * Otherwise, one array is a proper prefix of the other and, lexicographic
6689      * comparison is the result of comparing the two range lengths.
6690      * (See {@link #mismatch(long[], int, int, long[], int, int)} for the
6691      * definition of a common and proper prefix.)
6692      *
6693      * <p>The comparison is consistent with
6694      * {@link #equals(long[], int, int, long[], int, int) equals}, more
6695      * specifically the following holds for arrays {@code a} and {@code b} with
6696      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
6697      * [{@code bFromIndex}, {@code bToIndex}) respectively:
6698      * <pre>{@code
6699      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
6700      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
6701      * }</pre>
6702      *
6703      * @apiNote
6704      * <p>This method behaves as if:
6705      * <pre>{@code
6706      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6707      *                             b, bFromIndex, bToIndex);
6708      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6709      *         return Long.compare(a[aFromIndex + i], b[bFromIndex + i]);
6710      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6711      * }</pre>
6712      *
6713      * @param a the first array to compare
6714      * @param aFromIndex the index (inclusive) of the first element in the
6715      *                   first array to be compared
6716      * @param aToIndex the index (exclusive) of the last element in the
6717      *                 first array to be compared
6718      * @param b the second array to compare
6719      * @param bFromIndex the index (inclusive) of the first element in the
6720      *                   second array to be compared
6721      * @param bToIndex the index (exclusive) of the last element in the
6722      *                 second array to be compared
6723      * @return the value {@code 0} if, over the specified ranges, the first and
6724      *         second array are equal and contain the same elements in the same
6725      *         order;
6726      *         a value less than {@code 0} if, over the specified ranges, the
6727      *         first array is lexicographically less than the second array; and
6728      *         a value greater than {@code 0} if, over the specified ranges, the
6729      *         first array is lexicographically greater than the second array
6730      * @throws IllegalArgumentException
6731      *         if {@code aFromIndex > aToIndex} or
6732      *         if {@code bFromIndex > bToIndex}
6733      * @throws ArrayIndexOutOfBoundsException
6734      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6735      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6736      * @throws NullPointerException
6737      *         if either array is {@code null}
6738      * @since 9
6739      */
6740     public static int compare(long[] a, int aFromIndex, int aToIndex,
6741                               long[] b, int bFromIndex, int bToIndex) {
6742         rangeCheck(a.length, aFromIndex, aToIndex);
6743         rangeCheck(b.length, bFromIndex, bToIndex);
6744 
6745         int aLength = aToIndex - aFromIndex;
6746         int bLength = bToIndex - bFromIndex;
6747         int i = ArraysSupport.mismatch(a, aFromIndex,
6748                                        b, bFromIndex,
6749                                        Math.min(aLength, bLength));
6750         if (i >= 0) {
6751             return Long.compare(a[aFromIndex + i], b[bFromIndex + i]);
6752         }
6753 
6754         return aLength - bLength;
6755     }
6756 
6757     /**
6758      * Compares two {@code long} arrays lexicographically, numerically treating
6759      * elements as unsigned.
6760      *
6761      * <p>If the two arrays share a common prefix then the lexicographic
6762      * comparison is the result of comparing two elements, as if by
6763      * {@link Long#compareUnsigned(long, long)}, at an index within the
6764      * respective arrays that is the prefix length.
6765      * Otherwise, one array is a proper prefix of the other and, lexicographic
6766      * comparison is the result of comparing the two array lengths.
6767      * (See {@link #mismatch(long[], long[])} for the definition of a common
6768      * and proper prefix.)
6769      *
6770      * <p>A {@code null} array reference is considered lexicographically less
6771      * than a non-{@code null} array reference.  Two {@code null} array
6772      * references are considered equal.
6773      *
6774      * @apiNote
6775      * <p>This method behaves as if (for non-{@code null} array references):
6776      * <pre>{@code
6777      *     int i = Arrays.mismatch(a, b);
6778      *     if (i >= 0 && i < Math.min(a.length, b.length))
6779      *         return Long.compareUnsigned(a[i], b[i]);
6780      *     return a.length - b.length;
6781      * }</pre>
6782      *
6783      * @param a the first array to compare
6784      * @param b the second array to compare
6785      * @return the value {@code 0} if the first and second array are
6786      *         equal and contain the same elements in the same order;
6787      *         a value less than {@code 0} if the first array is
6788      *         lexicographically less than the second array; and
6789      *         a value greater than {@code 0} if the first array is
6790      *         lexicographically greater than the second array
6791      * @since 9
6792      */
6793     public static int compareUnsigned(long[] a, long[] b) {
6794         if (a == b)
6795             return 0;
6796         if (a == null || b == null)
6797             return a == null ? -1 : 1;
6798 
6799         int i = ArraysSupport.mismatch(a, b,
6800                                        Math.min(a.length, b.length));
6801         if (i >= 0) {
6802             return Long.compareUnsigned(a[i], b[i]);
6803         }
6804 
6805         return a.length - b.length;
6806     }
6807 
6808     /**
6809      * Compares two {@code long} arrays lexicographically over the specified
6810      * ranges, numerically treating elements as unsigned.
6811      *
6812      * <p>If the two arrays, over the specified ranges, share a common prefix
6813      * then the lexicographic comparison is the result of comparing two
6814      * elements, as if by {@link Long#compareUnsigned(long, long)}, at a
6815      * relative index within the respective arrays that is the length of the
6816      * prefix.
6817      * Otherwise, one array is a proper prefix of the other and, lexicographic
6818      * comparison is the result of comparing the two range lengths.
6819      * (See {@link #mismatch(long[], int, int, long[], int, int)} for the
6820      * definition of a common and proper prefix.)
6821      *
6822      * @apiNote
6823      * <p>This method behaves as if:
6824      * <pre>{@code
6825      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6826      *                             b, bFromIndex, bToIndex);
6827      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6828      *         return Long.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
6829      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6830      * }</pre>
6831      *
6832      * @param a the first array to compare
6833      * @param aFromIndex the index (inclusive) of the first element in the
6834      *                   first array to be compared
6835      * @param aToIndex the index (exclusive) of the last element in the
6836      *                 first array to be compared
6837      * @param b the second array to compare
6838      * @param bFromIndex the index (inclusive) of the first element in the
6839      *                   second array to be compared
6840      * @param bToIndex the index (exclusive) of the last element in the
6841      *                 second array to be compared
6842      * @return the value {@code 0} if, over the specified ranges, the first and
6843      *         second array are equal and contain the same elements in the same
6844      *         order;
6845      *         a value less than {@code 0} if, over the specified ranges, the
6846      *         first array is lexicographically less than the second array; and
6847      *         a value greater than {@code 0} if, over the specified ranges, the
6848      *         first array is lexicographically greater than the second array
6849      * @throws IllegalArgumentException
6850      *         if {@code aFromIndex > aToIndex} or
6851      *         if {@code bFromIndex > bToIndex}
6852      * @throws ArrayIndexOutOfBoundsException
6853      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6854      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6855      * @throws NullPointerException
6856      *         if either array is null
6857      * @since 9
6858      */
6859     public static int compareUnsigned(long[] a, int aFromIndex, int aToIndex,
6860                                       long[] b, int bFromIndex, int bToIndex) {
6861         rangeCheck(a.length, aFromIndex, aToIndex);
6862         rangeCheck(b.length, bFromIndex, bToIndex);
6863 
6864         int aLength = aToIndex - aFromIndex;
6865         int bLength = bToIndex - bFromIndex;
6866         int i = ArraysSupport.mismatch(a, aFromIndex,
6867                                        b, bFromIndex,
6868                                        Math.min(aLength, bLength));
6869         if (i >= 0) {
6870             return Long.compareUnsigned(a[aFromIndex + i], b[bFromIndex + i]);
6871         }
6872 
6873         return aLength - bLength;
6874     }
6875 
6876     // Compare float
6877 
6878     /**
6879      * Compares two {@code float} arrays lexicographically.
6880      *
6881      * <p>If the two arrays share a common prefix then the lexicographic
6882      * comparison is the result of comparing two elements, as if by
6883      * {@link Float#compare(float, float)}, at an index within the respective
6884      * arrays that is the prefix length.
6885      * Otherwise, one array is a proper prefix of the other and, lexicographic
6886      * comparison is the result of comparing the two array lengths.
6887      * (See {@link #mismatch(float[], float[])} for the definition of a common
6888      * and proper prefix.)
6889      *
6890      * <p>A {@code null} array reference is considered lexicographically less
6891      * than a non-{@code null} array reference.  Two {@code null} array
6892      * references are considered equal.
6893      *
6894      * <p>The comparison is consistent with {@link #equals(float[], float[]) equals},
6895      * more specifically the following holds for arrays {@code a} and {@code b}:
6896      * <pre>{@code
6897      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
6898      * }</pre>
6899      *
6900      * @apiNote
6901      * <p>This method behaves as if (for non-{@code null} array references):
6902      * <pre>{@code
6903      *     int i = Arrays.mismatch(a, b);
6904      *     if (i >= 0 && i < Math.min(a.length, b.length))
6905      *         return Float.compare(a[i], b[i]);
6906      *     return a.length - b.length;
6907      * }</pre>
6908      *
6909      * @param a the first array to compare
6910      * @param b the second array to compare
6911      * @return the value {@code 0} if the first and second array are equal and
6912      *         contain the same elements in the same order;
6913      *         a value less than {@code 0} if the first array is
6914      *         lexicographically less than the second array; and
6915      *         a value greater than {@code 0} if the first array is
6916      *         lexicographically greater than the second array
6917      * @since 9
6918      */
6919     public static int compare(float[] a, float[] b) {
6920         if (a == b)
6921             return 0;
6922         if (a == null || b == null)
6923             return a == null ? -1 : 1;
6924 
6925         int i = ArraysSupport.mismatch(a, b,
6926                                        Math.min(a.length, b.length));
6927         if (i >= 0) {
6928             return Float.compare(a[i], b[i]);
6929         }
6930 
6931         return a.length - b.length;
6932     }
6933 
6934     /**
6935      * Compares two {@code float} arrays lexicographically over the specified
6936      * ranges.
6937      *
6938      * <p>If the two arrays, over the specified ranges, share a common prefix
6939      * then the lexicographic comparison is the result of comparing two
6940      * elements, as if by {@link Float#compare(float, float)}, at a relative
6941      * index within the respective arrays that is the length of the prefix.
6942      * Otherwise, one array is a proper prefix of the other and, lexicographic
6943      * comparison is the result of comparing the two range lengths.
6944      * (See {@link #mismatch(float[], int, int, float[], int, int)} for the
6945      * definition of a common and proper prefix.)
6946      *
6947      * <p>The comparison is consistent with
6948      * {@link #equals(float[], int, int, float[], int, int) equals}, more
6949      * specifically the following holds for arrays {@code a} and {@code b} with
6950      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
6951      * [{@code bFromIndex}, {@code bToIndex}) respectively:
6952      * <pre>{@code
6953      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
6954      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
6955      * }</pre>
6956      *
6957      * @apiNote
6958      * <p>This method behaves as if:
6959      * <pre>{@code
6960      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
6961      *                             b, bFromIndex, bToIndex);
6962      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
6963      *         return Float.compare(a[aFromIndex + i], b[bFromIndex + i]);
6964      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
6965      * }</pre>
6966      *
6967      * @param a the first array to compare
6968      * @param aFromIndex the index (inclusive) of the first element in the
6969      *                   first array to be compared
6970      * @param aToIndex the index (exclusive) of the last element in the
6971      *                 first array to be compared
6972      * @param b the second array to compare
6973      * @param bFromIndex the index (inclusive) of the first element in the
6974      *                   second array to be compared
6975      * @param bToIndex the index (exclusive) of the last element in the
6976      *                 second array to be compared
6977      * @return the value {@code 0} if, over the specified ranges, the first and
6978      *         second array are equal and contain the same elements in the same
6979      *         order;
6980      *         a value less than {@code 0} if, over the specified ranges, the
6981      *         first array is lexicographically less than the second array; and
6982      *         a value greater than {@code 0} if, over the specified ranges, the
6983      *         first array is lexicographically greater than the second array
6984      * @throws IllegalArgumentException
6985      *         if {@code aFromIndex > aToIndex} or
6986      *         if {@code bFromIndex > bToIndex}
6987      * @throws ArrayIndexOutOfBoundsException
6988      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
6989      *         if {@code bFromIndex < 0 or bToIndex > b.length}
6990      * @throws NullPointerException
6991      *         if either array is {@code null}
6992      * @since 9
6993      */
6994     public static int compare(float[] a, int aFromIndex, int aToIndex,
6995                               float[] b, int bFromIndex, int bToIndex) {
6996         rangeCheck(a.length, aFromIndex, aToIndex);
6997         rangeCheck(b.length, bFromIndex, bToIndex);
6998 
6999         int aLength = aToIndex - aFromIndex;
7000         int bLength = bToIndex - bFromIndex;
7001         int i = ArraysSupport.mismatch(a, aFromIndex,
7002                                        b, bFromIndex,
7003                                        Math.min(aLength, bLength));
7004         if (i >= 0) {
7005             return Float.compare(a[aFromIndex + i], b[bFromIndex + i]);
7006         }
7007 
7008         return aLength - bLength;
7009     }
7010 
7011     // Compare double
7012 
7013     /**
7014      * Compares two {@code double} arrays lexicographically.
7015      *
7016      * <p>If the two arrays share a common prefix then the lexicographic
7017      * comparison is the result of comparing two elements, as if by
7018      * {@link Double#compare(double, double)}, at an index within the respective
7019      * arrays that is the prefix length.
7020      * Otherwise, one array is a proper prefix of the other and, lexicographic
7021      * comparison is the result of comparing the two array lengths.
7022      * (See {@link #mismatch(double[], double[])} for the definition of a common
7023      * and proper prefix.)
7024      *
7025      * <p>A {@code null} array reference is considered lexicographically less
7026      * than a non-{@code null} array reference.  Two {@code null} array
7027      * references are considered equal.
7028      *
7029      * <p>The comparison is consistent with {@link #equals(double[], double[]) equals},
7030      * more specifically the following holds for arrays {@code a} and {@code b}:
7031      * <pre>{@code
7032      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
7033      * }</pre>
7034      *
7035      * @apiNote
7036      * <p>This method behaves as if (for non-{@code null} array references):
7037      * <pre>{@code
7038      *     int i = Arrays.mismatch(a, b);
7039      *     if (i >= 0 && i < Math.min(a.length, b.length))
7040      *         return Double.compare(a[i], b[i]);
7041      *     return a.length - b.length;
7042      * }</pre>
7043      *
7044      * @param a the first array to compare
7045      * @param b the second array to compare
7046      * @return the value {@code 0} if the first and second array are equal and
7047      *         contain the same elements in the same order;
7048      *         a value less than {@code 0} if the first array is
7049      *         lexicographically less than the second array; and
7050      *         a value greater than {@code 0} if the first array is
7051      *         lexicographically greater than the second array
7052      * @since 9
7053      */
7054     public static int compare(double[] a, double[] b) {
7055         if (a == b)
7056             return 0;
7057         if (a == null || b == null)
7058             return a == null ? -1 : 1;
7059 
7060         int i = ArraysSupport.mismatch(a, b,
7061                                        Math.min(a.length, b.length));
7062         if (i >= 0) {
7063             return Double.compare(a[i], b[i]);
7064         }
7065 
7066         return a.length - b.length;
7067     }
7068 
7069     /**
7070      * Compares two {@code double} arrays lexicographically over the specified
7071      * ranges.
7072      *
7073      * <p>If the two arrays, over the specified ranges, share a common prefix
7074      * then the lexicographic comparison is the result of comparing two
7075      * elements, as if by {@link Double#compare(double, double)}, at a relative
7076      * index within the respective arrays that is the length of the prefix.
7077      * Otherwise, one array is a proper prefix of the other and, lexicographic
7078      * comparison is the result of comparing the two range lengths.
7079      * (See {@link #mismatch(double[], int, int, double[], int, int)} for the
7080      * definition of a common and proper prefix.)
7081      *
7082      * <p>The comparison is consistent with
7083      * {@link #equals(double[], int, int, double[], int, int) equals}, more
7084      * specifically the following holds for arrays {@code a} and {@code b} with
7085      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
7086      * [{@code bFromIndex}, {@code bToIndex}) respectively:
7087      * <pre>{@code
7088      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
7089      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
7090      * }</pre>
7091      *
7092      * @apiNote
7093      * <p>This method behaves as if:
7094      * <pre>{@code
7095      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
7096      *                             b, bFromIndex, bToIndex);
7097      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
7098      *         return Double.compare(a[aFromIndex + i], b[bFromIndex + i]);
7099      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
7100      * }</pre>
7101      *
7102      * @param a the first array to compare
7103      * @param aFromIndex the index (inclusive) of the first element in the
7104      *                   first array to be compared
7105      * @param aToIndex the index (exclusive) of the last element in the
7106      *                 first array to be compared
7107      * @param b the second array to compare
7108      * @param bFromIndex the index (inclusive) of the first element in the
7109      *                   second array to be compared
7110      * @param bToIndex the index (exclusive) of the last element in the
7111      *                 second array to be compared
7112      * @return the value {@code 0} if, over the specified ranges, the first and
7113      *         second array are equal and contain the same elements in the same
7114      *         order;
7115      *         a value less than {@code 0} if, over the specified ranges, the
7116      *         first array is lexicographically less than the second array; and
7117      *         a value greater than {@code 0} if, over the specified ranges, the
7118      *         first array is lexicographically greater than the second array
7119      * @throws IllegalArgumentException
7120      *         if {@code aFromIndex > aToIndex} or
7121      *         if {@code bFromIndex > bToIndex}
7122      * @throws ArrayIndexOutOfBoundsException
7123      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
7124      *         if {@code bFromIndex < 0 or bToIndex > b.length}
7125      * @throws NullPointerException
7126      *         if either array is {@code null}
7127      * @since 9
7128      */
7129     public static int compare(double[] a, int aFromIndex, int aToIndex,
7130                               double[] b, int bFromIndex, int bToIndex) {
7131         rangeCheck(a.length, aFromIndex, aToIndex);
7132         rangeCheck(b.length, bFromIndex, bToIndex);
7133 
7134         int aLength = aToIndex - aFromIndex;
7135         int bLength = bToIndex - bFromIndex;
7136         int i = ArraysSupport.mismatch(a, aFromIndex,
7137                                        b, bFromIndex,
7138                                        Math.min(aLength, bLength));
7139         if (i >= 0) {
7140             return Double.compare(a[aFromIndex + i], b[bFromIndex + i]);
7141         }
7142 
7143         return aLength - bLength;
7144     }
7145 
7146     // Compare objects
7147 
7148     /**
7149      * Compares two {@code Object} arrays, within comparable elements,
7150      * lexicographically.
7151      *
7152      * <p>If the two arrays share a common prefix then the lexicographic
7153      * comparison is the result of comparing two elements of type {@code T} at
7154      * an index {@code i} within the respective arrays that is the prefix
7155      * length, as if by:
7156      * <pre>{@code
7157      *     Comparator.nullsFirst(Comparator.<T>naturalOrder()).
7158      *         compare(a[i], b[i])
7159      * }</pre>
7160      * Otherwise, one array is a proper prefix of the other and, lexicographic
7161      * comparison is the result of comparing the two array lengths.
7162      * (See {@link #mismatch(Object[], Object[])} for the definition of a common
7163      * and proper prefix.)
7164      *
7165      * <p>A {@code null} array reference is considered lexicographically less
7166      * than a non-{@code null} array reference. Two {@code null} array
7167      * references are considered equal.
7168      * A {@code null} array element is considered lexicographically less than a
7169      * non-{@code null} array element. Two {@code null} array elements are
7170      * considered equal.
7171      *
7172      * <p>The comparison is consistent with {@link #equals(Object[], Object[]) equals},
7173      * more specifically the following holds for arrays {@code a} and {@code b}:
7174      * <pre>{@code
7175      *     Arrays.equals(a, b) == (Arrays.compare(a, b) == 0)
7176      * }</pre>
7177      *
7178      * @apiNote
7179      * <p>This method behaves as if (for non-{@code null} array references
7180      * and elements):
7181      * <pre>{@code
7182      *     int i = Arrays.mismatch(a, b);
7183      *     if (i >= 0 && i < Math.min(a.length, b.length))
7184      *         return a[i].compareTo(b[i]);
7185      *     return a.length - b.length;
7186      * }</pre>
7187      *
7188      * @param a the first array to compare
7189      * @param b the second array to compare
7190      * @param <T> the type of comparable array elements
7191      * @return the value {@code 0} if the first and second array are equal and
7192      *         contain the same elements in the same order;
7193      *         a value less than {@code 0} if the first array is
7194      *         lexicographically less than the second array; and
7195      *         a value greater than {@code 0} if the first array is
7196      *         lexicographically greater than the second array
7197      * @since 9
7198      */
7199     public static <T extends Comparable<? super T>> int compare(T[] a, T[] b) {
7200         if (a == b)
7201             return 0;
7202         // A null array is less than a non-null array
7203         if (a == null || b == null)
7204             return a == null ? -1 : 1;
7205 
7206         int length = Math.min(a.length, b.length);
7207         for (int i = 0; i < length; i++) {
7208             T oa = a[i];
7209             T ob = b[i];
7210             if (oa != ob) {
7211                 // A null element is less than a non-null element
7212                 if (oa == null || ob == null)
7213                     return oa == null ? -1 : 1;
7214                 int v = oa.compareTo(ob);
7215                 if (v != 0) {
7216                     return v;
7217                 }
7218             }
7219         }
7220 
7221         return a.length - b.length;
7222     }
7223 
7224     /**
7225      * Compares two {@code Object} arrays lexicographically over the specified
7226      * ranges.
7227      *
7228      * <p>If the two arrays, over the specified ranges, share a common prefix
7229      * then the lexicographic comparison is the result of comparing two
7230      * elements of type {@code T} at a relative index {@code i} within the
7231      * respective arrays that is the prefix length, as if by:
7232      * <pre>{@code
7233      *     Comparator.nullsFirst(Comparator.<T>naturalOrder()).
7234      *         compare(a[aFromIndex + i, b[bFromIndex + i])
7235      * }</pre>
7236      * Otherwise, one array is a proper prefix of the other and, lexicographic
7237      * comparison is the result of comparing the two range lengths.
7238      * (See {@link #mismatch(Object[], int, int, Object[], int, int)} for the
7239      * definition of a common and proper prefix.)
7240      *
7241      * <p>The comparison is consistent with
7242      * {@link #equals(Object[], int, int, Object[], int, int) equals}, more
7243      * specifically the following holds for arrays {@code a} and {@code b} with
7244      * specified ranges [{@code aFromIndex}, {@code aToIndex}) and
7245      * [{@code bFromIndex}, {@code bToIndex}) respectively:
7246      * <pre>{@code
7247      *     Arrays.equals(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) ==
7248      *         (Arrays.compare(a, aFromIndex, aToIndex, b, bFromIndex, bToIndex) == 0)
7249      * }</pre>
7250      *
7251      * @apiNote
7252      * <p>This method behaves as if (for non-{@code null} array elements):
7253      * <pre>{@code
7254      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
7255      *                             b, bFromIndex, bToIndex);
7256      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
7257      *         return a[aFromIndex + i].compareTo(b[bFromIndex + i]);
7258      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
7259      * }</pre>
7260      *
7261      * @param a the first array to compare
7262      * @param aFromIndex the index (inclusive) of the first element in the
7263      *                   first array to be compared
7264      * @param aToIndex the index (exclusive) of the last element in the
7265      *                 first array to be compared
7266      * @param b the second array to compare
7267      * @param bFromIndex the index (inclusive) of the first element in the
7268      *                   second array to be compared
7269      * @param bToIndex the index (exclusive) of the last element in the
7270      *                 second array to be compared
7271      * @param <T> the type of comparable array elements
7272      * @return the value {@code 0} if, over the specified ranges, the first and
7273      *         second array are equal and contain the same elements in the same
7274      *         order;
7275      *         a value less than {@code 0} if, over the specified ranges, the
7276      *         first array is lexicographically less than the second array; and
7277      *         a value greater than {@code 0} if, over the specified ranges, the
7278      *         first array is lexicographically greater than the second array
7279      * @throws IllegalArgumentException
7280      *         if {@code aFromIndex > aToIndex} or
7281      *         if {@code bFromIndex > bToIndex}
7282      * @throws ArrayIndexOutOfBoundsException
7283      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
7284      *         if {@code bFromIndex < 0 or bToIndex > b.length}
7285      * @throws NullPointerException
7286      *         if either array is {@code null}
7287      * @since 9
7288      */
7289     public static <T extends Comparable<? super T>> int compare(
7290             T[] a, int aFromIndex, int aToIndex,
7291             T[] b, int bFromIndex, int bToIndex) {
7292         rangeCheck(a.length, aFromIndex, aToIndex);
7293         rangeCheck(b.length, bFromIndex, bToIndex);
7294 
7295         int aLength = aToIndex - aFromIndex;
7296         int bLength = bToIndex - bFromIndex;
7297         int length = Math.min(aLength, bLength);
7298         for (int i = 0; i < length; i++) {
7299             T oa = a[aFromIndex++];
7300             T ob = b[bFromIndex++];
7301             if (oa != ob) {
7302                 if (oa == null || ob == null)
7303                     return oa == null ? -1 : 1;
7304                 int v = oa.compareTo(ob);
7305                 if (v != 0) {
7306                     return v;
7307                 }
7308             }
7309         }
7310 
7311         return aLength - bLength;
7312     }
7313 
7314     /**
7315      * Compares two {@code Object} arrays lexicographically using a specified
7316      * comparator.
7317      *
7318      * <p>If the two arrays share a common prefix then the lexicographic
7319      * comparison is the result of comparing with the specified comparator two
7320      * elements at an index within the respective arrays that is the prefix
7321      * length.
7322      * Otherwise, one array is a proper prefix of the other and, lexicographic
7323      * comparison is the result of comparing the two array lengths.
7324      * (See {@link #mismatch(Object[], Object[])} for the definition of a common
7325      * and proper prefix.)
7326      *
7327      * <p>A {@code null} array reference is considered lexicographically less
7328      * than a non-{@code null} array reference.  Two {@code null} array
7329      * references are considered equal.
7330      *
7331      * @apiNote
7332      * <p>This method behaves as if (for non-{@code null} array references):
7333      * <pre>{@code
7334      *     int i = Arrays.mismatch(a, b, cmp);
7335      *     if (i >= 0 && i < Math.min(a.length, b.length))
7336      *         return cmp.compare(a[i], b[i]);
7337      *     return a.length - b.length;
7338      * }</pre>
7339      *
7340      * @param a the first array to compare
7341      * @param b the second array to compare
7342      * @param cmp the comparator to compare array elements
7343      * @param <T> the type of array elements
7344      * @return the value {@code 0} if the first and second array are equal and
7345      *         contain the same elements in the same order;
7346      *         a value less than {@code 0} if the first array is
7347      *         lexicographically less than the second array; and
7348      *         a value greater than {@code 0} if the first array is
7349      *         lexicographically greater than the second array
7350      * @throws NullPointerException if the comparator is {@code null}
7351      * @since 9
7352      */
7353     public static <T> int compare(T[] a, T[] b,
7354                                   Comparator<? super T> cmp) {
7355         Objects.requireNonNull(cmp);
7356         if (a == b)
7357             return 0;
7358         if (a == null || b == null)
7359             return a == null ? -1 : 1;
7360 
7361         int length = Math.min(a.length, b.length);
7362         for (int i = 0; i < length; i++) {
7363             T oa = a[i];
7364             T ob = b[i];
7365             if (oa != ob) {
7366                 // Null-value comparison is deferred to the comparator
7367                 int v = cmp.compare(oa, ob);
7368                 if (v != 0) {
7369                     return v;
7370                 }
7371             }
7372         }
7373 
7374         return a.length - b.length;
7375     }
7376 
7377     /**
7378      * Compares two {@code Object} arrays lexicographically over the specified
7379      * ranges.
7380      *
7381      * <p>If the two arrays, over the specified ranges, share a common prefix
7382      * then the lexicographic comparison is the result of comparing with the
7383      * specified comparator two elements at a relative index within the
7384      * respective arrays that is the prefix length.
7385      * Otherwise, one array is a proper prefix of the other and, lexicographic
7386      * comparison is the result of comparing the two range lengths.
7387      * (See {@link #mismatch(Object[], int, int, Object[], int, int)} for the
7388      * definition of a common and proper prefix.)
7389      *
7390      * @apiNote
7391      * <p>This method behaves as if (for non-{@code null} array elements):
7392      * <pre>{@code
7393      *     int i = Arrays.mismatch(a, aFromIndex, aToIndex,
7394      *                             b, bFromIndex, bToIndex, cmp);
7395      *     if (i >= 0 && i < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
7396      *         return cmp.compare(a[aFromIndex + i], b[bFromIndex + i]);
7397      *     return (aToIndex - aFromIndex) - (bToIndex - bFromIndex);
7398      * }</pre>
7399      *
7400      * @param a the first array to compare
7401      * @param aFromIndex the index (inclusive) of the first element in the
7402      *                   first array to be compared
7403      * @param aToIndex the index (exclusive) of the last element in the
7404      *                 first array to be compared
7405      * @param b the second array to compare
7406      * @param bFromIndex the index (inclusive) of the first element in the
7407      *                   second array to be compared
7408      * @param bToIndex the index (exclusive) of the last element in the
7409      *                 second array to be compared
7410      * @param cmp the comparator to compare array elements
7411      * @param <T> the type of array elements
7412      * @return the value {@code 0} if, over the specified ranges, the first and
7413      *         second array are equal and contain the same elements in the same
7414      *         order;
7415      *         a value less than {@code 0} if, over the specified ranges, the
7416      *         first array is lexicographically less than the second array; and
7417      *         a value greater than {@code 0} if, over the specified ranges, the
7418      *         first array is lexicographically greater than the second array
7419      * @throws IllegalArgumentException
7420      *         if {@code aFromIndex > aToIndex} or
7421      *         if {@code bFromIndex > bToIndex}
7422      * @throws ArrayIndexOutOfBoundsException
7423      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
7424      *         if {@code bFromIndex < 0 or bToIndex > b.length}
7425      * @throws NullPointerException
7426      *         if either array or the comparator is {@code null}
7427      * @since 9
7428      */
7429     public static <T> int compare(
7430             T[] a, int aFromIndex, int aToIndex,
7431             T[] b, int bFromIndex, int bToIndex,
7432             Comparator<? super T> cmp) {
7433         Objects.requireNonNull(cmp);
7434         rangeCheck(a.length, aFromIndex, aToIndex);
7435         rangeCheck(b.length, bFromIndex, bToIndex);
7436 
7437         int aLength = aToIndex - aFromIndex;
7438         int bLength = bToIndex - bFromIndex;
7439         int length = Math.min(aLength, bLength);
7440         for (int i = 0; i < length; i++) {
7441             T oa = a[aFromIndex++];
7442             T ob = b[bFromIndex++];
7443             if (oa != ob) {
7444                 // Null-value comparison is deferred to the comparator
7445                 int v = cmp.compare(oa, ob);
7446                 if (v != 0) {
7447                     return v;
7448                 }
7449             }
7450         }
7451 
7452         return aLength - bLength;
7453     }
7454 
7455 
7456     // Mismatch methods
7457 
7458     // Mismatch boolean
7459 
7460     /**
7461      * Finds and returns the index of the first mismatch between two
7462      * {@code boolean} arrays, otherwise return -1 if no mismatch is found.  The
7463      * index will be in the range of 0 (inclusive) up to the length (inclusive)
7464      * of the smaller array.
7465      *
7466      * <p>If the two arrays share a common prefix then the returned index is the
7467      * length of the common prefix and it follows that there is a mismatch
7468      * between the two elements at that index within the respective arrays.
7469      * If one array is a proper prefix of the other then the returned index is
7470      * the length of the smaller array and it follows that the index is only
7471      * valid for the larger array.
7472      * Otherwise, there is no mismatch.
7473      *
7474      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
7475      * prefix of length {@code pl} if the following expression is true:
7476      * <pre>{@code
7477      *     pl >= 0 &&
7478      *     pl < Math.min(a.length, b.length) &&
7479      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
7480      *     a[pl] != b[pl]
7481      * }</pre>
7482      * Note that a common prefix length of {@code 0} indicates that the first
7483      * elements from each array mismatch.
7484      *
7485      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
7486      * prefix if the following expression is true:
7487      * <pre>{@code
7488      *     a.length != b.length &&
7489      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
7490      *                   b, 0, Math.min(a.length, b.length))
7491      * }</pre>
7492      *
7493      * @param a the first array to be tested for a mismatch
7494      * @param b the second array to be tested for a mismatch
7495      * @return the index of the first mismatch between the two arrays,
7496      *         otherwise {@code -1}.
7497      * @throws NullPointerException
7498      *         if either array is {@code null}
7499      * @since 9
7500      */
7501     public static int mismatch(boolean[] a, boolean[] b) {
7502         int length = Math.min(a.length, b.length); // Check null array refs
7503         if (a == b)
7504             return -1;
7505 
7506         int i = ArraysSupport.mismatch(a, b, length);
7507         return (i < 0 && a.length != b.length) ? length : i;
7508     }
7509 
7510     /**
7511      * Finds and returns the relative index of the first mismatch between two
7512      * {@code boolean} arrays over the specified ranges, otherwise return -1 if
7513      * no mismatch is found.  The index will be in the range of 0 (inclusive) up
7514      * to the length (inclusive) of the smaller range.
7515      *
7516      * <p>If the two arrays, over the specified ranges, share a common prefix
7517      * then the returned relative index is the length of the common prefix and
7518      * it follows that there is a mismatch between the two elements at that
7519      * relative index within the respective arrays.
7520      * If one array is a proper prefix of the other, over the specified ranges,
7521      * then the returned relative index is the length of the smaller range and
7522      * it follows that the relative index is only valid for the array with the
7523      * larger range.
7524      * Otherwise, there is no mismatch.
7525      *
7526      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7527      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7528      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
7529      * prefix of length {@code pl} if the following expression is true:
7530      * <pre>{@code
7531      *     pl >= 0 &&
7532      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
7533      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
7534      *     a[aFromIndex + pl] != b[bFromIndex + pl]
7535      * }</pre>
7536      * Note that a common prefix length of {@code 0} indicates that the first
7537      * elements from each array mismatch.
7538      *
7539      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7540      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7541      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
7542      * prefix if the following expression is true:
7543      * <pre>{@code
7544      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
7545      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
7546      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
7547      * }</pre>
7548      *
7549      * @param a the first array to be tested for a mismatch
7550      * @param aFromIndex the index (inclusive) of the first element in the
7551      *                   first array to be tested
7552      * @param aToIndex the index (exclusive) of the last element in the
7553      *                 first array to be tested
7554      * @param b the second array to be tested for a mismatch
7555      * @param bFromIndex the index (inclusive) of the first element in the
7556      *                   second array to be tested
7557      * @param bToIndex the index (exclusive) of the last element in the
7558      *                 second array to be tested
7559      * @return the relative index of the first mismatch between the two arrays
7560      *         over the specified ranges, otherwise {@code -1}.
7561      * @throws IllegalArgumentException
7562      *         if {@code aFromIndex > aToIndex} or
7563      *         if {@code bFromIndex > bToIndex}
7564      * @throws ArrayIndexOutOfBoundsException
7565      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
7566      *         if {@code bFromIndex < 0 or bToIndex > b.length}
7567      * @throws NullPointerException
7568      *         if either array is {@code null}
7569      * @since 9
7570      */
7571     public static int mismatch(boolean[] a, int aFromIndex, int aToIndex,
7572                                boolean[] b, int bFromIndex, int bToIndex) {
7573         rangeCheck(a.length, aFromIndex, aToIndex);
7574         rangeCheck(b.length, bFromIndex, bToIndex);
7575 
7576         int aLength = aToIndex - aFromIndex;
7577         int bLength = bToIndex - bFromIndex;
7578         int length = Math.min(aLength, bLength);
7579         int i = ArraysSupport.mismatch(a, aFromIndex,
7580                                        b, bFromIndex,
7581                                        length);
7582         return (i < 0 && aLength != bLength) ? length : i;
7583     }
7584 
7585     // Mismatch byte
7586 
7587     /**
7588      * Finds and returns the index of the first mismatch between two {@code byte}
7589      * arrays, otherwise return -1 if no mismatch is found.  The index will be
7590      * in the range of 0 (inclusive) up to the length (inclusive) of the smaller
7591      * array.
7592      *
7593      * <p>If the two arrays share a common prefix then the returned index is the
7594      * length of the common prefix and it follows that there is a mismatch
7595      * between the two elements at that index within the respective arrays.
7596      * If one array is a proper prefix of the other then the returned index is
7597      * the length of the smaller array and it follows that the index is only
7598      * valid for the larger array.
7599      * Otherwise, there is no mismatch.
7600      *
7601      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
7602      * prefix of length {@code pl} if the following expression is true:
7603      * <pre>{@code
7604      *     pl >= 0 &&
7605      *     pl < Math.min(a.length, b.length) &&
7606      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
7607      *     a[pl] != b[pl]
7608      * }</pre>
7609      * Note that a common prefix length of {@code 0} indicates that the first
7610      * elements from each array mismatch.
7611      *
7612      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
7613      * prefix if the following expression is true:
7614      * <pre>{@code
7615      *     a.length != b.length &&
7616      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
7617      *                   b, 0, Math.min(a.length, b.length))
7618      * }</pre>
7619      *
7620      * @param a the first array to be tested for a mismatch
7621      * @param b the second array to be tested for a mismatch
7622      * @return the index of the first mismatch between the two arrays,
7623      *         otherwise {@code -1}.
7624      * @throws NullPointerException
7625      *         if either array is {@code null}
7626      * @since 9
7627      */
7628     public static int mismatch(byte[] a, byte[] b) {
7629         int length = Math.min(a.length, b.length); // Check null array refs
7630         if (a == b)
7631             return -1;
7632 
7633         int i = ArraysSupport.mismatch(a, b, length);
7634         return (i < 0 && a.length != b.length) ? length : i;
7635     }
7636 
7637     /**
7638      * Finds and returns the relative index of the first mismatch between two
7639      * {@code byte} arrays over the specified ranges, otherwise return -1 if no
7640      * mismatch is found.  The index will be in the range of 0 (inclusive) up to
7641      * the length (inclusive) of the smaller range.
7642      *
7643      * <p>If the two arrays, over the specified ranges, share a common prefix
7644      * then the returned relative index is the length of the common prefix and
7645      * it follows that there is a mismatch between the two elements at that
7646      * relative index within the respective arrays.
7647      * If one array is a proper prefix of the other, over the specified ranges,
7648      * then the returned relative index is the length of the smaller range and
7649      * it follows that the relative index is only valid for the array with the
7650      * larger range.
7651      * Otherwise, there is no mismatch.
7652      *
7653      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7654      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7655      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
7656      * prefix of length {@code pl} if the following expression is true:
7657      * <pre>{@code
7658      *     pl >= 0 &&
7659      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
7660      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
7661      *     a[aFromIndex + pl] != b[bFromIndex + pl]
7662      * }</pre>
7663      * Note that a common prefix length of {@code 0} indicates that the first
7664      * elements from each array mismatch.
7665      *
7666      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7667      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7668      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
7669      * prefix if the following expression is true:
7670      * <pre>{@code
7671      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
7672      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
7673      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
7674      * }</pre>
7675      *
7676      * @param a the first array to be tested for a mismatch
7677      * @param aFromIndex the index (inclusive) of the first element in the
7678      *                   first array to be tested
7679      * @param aToIndex the index (exclusive) of the last element in the
7680      *                 first array to be tested
7681      * @param b the second array to be tested for a mismatch
7682      * @param bFromIndex the index (inclusive) of the first element in the
7683      *                   second array to be tested
7684      * @param bToIndex the index (exclusive) of the last element in the
7685      *                 second array to be tested
7686      * @return the relative index of the first mismatch between the two arrays
7687      *         over the specified ranges, otherwise {@code -1}.
7688      * @throws IllegalArgumentException
7689      *         if {@code aFromIndex > aToIndex} or
7690      *         if {@code bFromIndex > bToIndex}
7691      * @throws ArrayIndexOutOfBoundsException
7692      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
7693      *         if {@code bFromIndex < 0 or bToIndex > b.length}
7694      * @throws NullPointerException
7695      *         if either array is {@code null}
7696      * @since 9
7697      */
7698     public static int mismatch(byte[] a, int aFromIndex, int aToIndex,
7699                                byte[] b, int bFromIndex, int bToIndex) {
7700         rangeCheck(a.length, aFromIndex, aToIndex);
7701         rangeCheck(b.length, bFromIndex, bToIndex);
7702 
7703         int aLength = aToIndex - aFromIndex;
7704         int bLength = bToIndex - bFromIndex;
7705         int length = Math.min(aLength, bLength);
7706         int i = ArraysSupport.mismatch(a, aFromIndex,
7707                                        b, bFromIndex,
7708                                        length);
7709         return (i < 0 && aLength != bLength) ? length : i;
7710     }
7711 
7712     // Mismatch char
7713 
7714     /**
7715      * Finds and returns the index of the first mismatch between two {@code char}
7716      * arrays, otherwise return -1 if no mismatch is found.  The index will be
7717      * in the range of 0 (inclusive) up to the length (inclusive) of the smaller
7718      * array.
7719      *
7720      * <p>If the two arrays share a common prefix then the returned index is the
7721      * length of the common prefix and it follows that there is a mismatch
7722      * between the two elements at that index within the respective arrays.
7723      * If one array is a proper prefix of the other then the returned index is
7724      * the length of the smaller array and it follows that the index is only
7725      * valid for the larger array.
7726      * Otherwise, there is no mismatch.
7727      *
7728      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
7729      * prefix of length {@code pl} if the following expression is true:
7730      * <pre>{@code
7731      *     pl >= 0 &&
7732      *     pl < Math.min(a.length, b.length) &&
7733      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
7734      *     a[pl] != b[pl]
7735      * }</pre>
7736      * Note that a common prefix length of {@code 0} indicates that the first
7737      * elements from each array mismatch.
7738      *
7739      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
7740      * prefix if the following expression is true:
7741      * <pre>{@code
7742      *     a.length != b.length &&
7743      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
7744      *                   b, 0, Math.min(a.length, b.length))
7745      * }</pre>
7746      *
7747      * @param a the first array to be tested for a mismatch
7748      * @param b the second array to be tested for a mismatch
7749      * @return the index of the first mismatch between the two arrays,
7750      *         otherwise {@code -1}.
7751      * @throws NullPointerException
7752      *         if either array is {@code null}
7753      * @since 9
7754      */
7755     public static int mismatch(char[] a, char[] b) {
7756         int length = Math.min(a.length, b.length); // Check null array refs
7757         if (a == b)
7758             return -1;
7759 
7760         int i = ArraysSupport.mismatch(a, b, length);
7761         return (i < 0 && a.length != b.length) ? length : i;
7762     }
7763 
7764     /**
7765      * Finds and returns the relative index of the first mismatch between two
7766      * {@code char} arrays over the specified ranges, otherwise return -1 if no
7767      * mismatch is found.  The index will be in the range of 0 (inclusive) up to
7768      * the length (inclusive) of the smaller range.
7769      *
7770      * <p>If the two arrays, over the specified ranges, share a common prefix
7771      * then the returned relative index is the length of the common prefix and
7772      * it follows that there is a mismatch between the two elements at that
7773      * relative index within the respective arrays.
7774      * If one array is a proper prefix of the other, over the specified ranges,
7775      * then the returned relative index is the length of the smaller range and
7776      * it follows that the relative index is only valid for the array with the
7777      * larger range.
7778      * Otherwise, there is no mismatch.
7779      *
7780      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7781      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7782      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
7783      * prefix of length {@code pl} if the following expression is true:
7784      * <pre>{@code
7785      *     pl >= 0 &&
7786      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
7787      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
7788      *     a[aFromIndex + pl] != b[bFromIndex + pl]
7789      * }</pre>
7790      * Note that a common prefix length of {@code 0} indicates that the first
7791      * elements from each array mismatch.
7792      *
7793      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7794      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7795      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
7796      * prefix if the following expression is true:
7797      * <pre>{@code
7798      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
7799      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
7800      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
7801      * }</pre>
7802      *
7803      * @param a the first array to be tested for a mismatch
7804      * @param aFromIndex the index (inclusive) of the first element in the
7805      *                   first array to be tested
7806      * @param aToIndex the index (exclusive) of the last element in the
7807      *                 first array to be tested
7808      * @param b the second array to be tested for a mismatch
7809      * @param bFromIndex the index (inclusive) of the first element in the
7810      *                   second array to be tested
7811      * @param bToIndex the index (exclusive) of the last element in the
7812      *                 second array to be tested
7813      * @return the relative index of the first mismatch between the two arrays
7814      *         over the specified ranges, otherwise {@code -1}.
7815      * @throws IllegalArgumentException
7816      *         if {@code aFromIndex > aToIndex} or
7817      *         if {@code bFromIndex > bToIndex}
7818      * @throws ArrayIndexOutOfBoundsException
7819      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
7820      *         if {@code bFromIndex < 0 or bToIndex > b.length}
7821      * @throws NullPointerException
7822      *         if either array is {@code null}
7823      * @since 9
7824      */
7825     public static int mismatch(char[] a, int aFromIndex, int aToIndex,
7826                                char[] b, int bFromIndex, int bToIndex) {
7827         rangeCheck(a.length, aFromIndex, aToIndex);
7828         rangeCheck(b.length, bFromIndex, bToIndex);
7829 
7830         int aLength = aToIndex - aFromIndex;
7831         int bLength = bToIndex - bFromIndex;
7832         int length = Math.min(aLength, bLength);
7833         int i = ArraysSupport.mismatch(a, aFromIndex,
7834                                        b, bFromIndex,
7835                                        length);
7836         return (i < 0 && aLength != bLength) ? length : i;
7837     }
7838 
7839     // Mismatch short
7840 
7841     /**
7842      * Finds and returns the index of the first mismatch between two {@code short}
7843      * arrays, otherwise return -1 if no mismatch is found.  The index will be
7844      * in the range of 0 (inclusive) up to the length (inclusive) of the smaller
7845      * array.
7846      *
7847      * <p>If the two arrays share a common prefix then the returned index is the
7848      * length of the common prefix and it follows that there is a mismatch
7849      * between the two elements at that index within the respective arrays.
7850      * If one array is a proper prefix of the other then the returned index is
7851      * the length of the smaller array and it follows that the index is only
7852      * valid for the larger array.
7853      * Otherwise, there is no mismatch.
7854      *
7855      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
7856      * prefix of length {@code pl} if the following expression is true:
7857      * <pre>{@code
7858      *     pl >= 0 &&
7859      *     pl < Math.min(a.length, b.length) &&
7860      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
7861      *     a[pl] != b[pl]
7862      * }</pre>
7863      * Note that a common prefix length of {@code 0} indicates that the first
7864      * elements from each array mismatch.
7865      *
7866      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
7867      * prefix if the following expression is true:
7868      * <pre>{@code
7869      *     a.length != b.length &&
7870      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
7871      *                   b, 0, Math.min(a.length, b.length))
7872      * }</pre>
7873      *
7874      * @param a the first array to be tested for a mismatch
7875      * @param b the second array to be tested for a mismatch
7876      * @return the index of the first mismatch between the two arrays,
7877      *         otherwise {@code -1}.
7878      * @throws NullPointerException
7879      *         if either array is {@code null}
7880      * @since 9
7881      */
7882     public static int mismatch(short[] a, short[] b) {
7883         int length = Math.min(a.length, b.length); // Check null array refs
7884         if (a == b)
7885             return -1;
7886 
7887         int i = ArraysSupport.mismatch(a, b, length);
7888         return (i < 0 && a.length != b.length) ? length : i;
7889     }
7890 
7891     /**
7892      * Finds and returns the relative index of the first mismatch between two
7893      * {@code short} arrays over the specified ranges, otherwise return -1 if no
7894      * mismatch is found.  The index will be in the range of 0 (inclusive) up to
7895      * the length (inclusive) of the smaller range.
7896      *
7897      * <p>If the two arrays, over the specified ranges, share a common prefix
7898      * then the returned relative index is the length of the common prefix and
7899      * it follows that there is a mismatch between the two elements at that
7900      * relative index within the respective arrays.
7901      * If one array is a proper prefix of the other, over the specified ranges,
7902      * then the returned relative index is the length of the smaller range and
7903      * it follows that the relative index is only valid for the array with the
7904      * larger range.
7905      * Otherwise, there is no mismatch.
7906      *
7907      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7908      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7909      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
7910      * prefix of length {@code pl} if the following expression is true:
7911      * <pre>{@code
7912      *     pl >= 0 &&
7913      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
7914      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
7915      *     a[aFromIndex + pl] != b[bFromIndex + pl]
7916      * }</pre>
7917      * Note that a common prefix length of {@code 0} indicates that the first
7918      * elements from each array mismatch.
7919      *
7920      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
7921      * ranges [{@code aFromIndex}, {@code aToIndex}) and
7922      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
7923      * prefix if the following expression is true:
7924      * <pre>{@code
7925      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
7926      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
7927      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
7928      * }</pre>
7929      *
7930      * @param a the first array to be tested for a mismatch
7931      * @param aFromIndex the index (inclusive) of the first element in the
7932      *                   first array to be tested
7933      * @param aToIndex the index (exclusive) of the last element in the
7934      *                 first array to be tested
7935      * @param b the second array to be tested for a mismatch
7936      * @param bFromIndex the index (inclusive) of the first element in the
7937      *                   second array to be tested
7938      * @param bToIndex the index (exclusive) of the last element in the
7939      *                 second array to be tested
7940      * @return the relative index of the first mismatch between the two arrays
7941      *         over the specified ranges, otherwise {@code -1}.
7942      * @throws IllegalArgumentException
7943      *         if {@code aFromIndex > aToIndex} or
7944      *         if {@code bFromIndex > bToIndex}
7945      * @throws ArrayIndexOutOfBoundsException
7946      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
7947      *         if {@code bFromIndex < 0 or bToIndex > b.length}
7948      * @throws NullPointerException
7949      *         if either array is {@code null}
7950      * @since 9
7951      */
7952     public static int mismatch(short[] a, int aFromIndex, int aToIndex,
7953                                short[] b, int bFromIndex, int bToIndex) {
7954         rangeCheck(a.length, aFromIndex, aToIndex);
7955         rangeCheck(b.length, bFromIndex, bToIndex);
7956 
7957         int aLength = aToIndex - aFromIndex;
7958         int bLength = bToIndex - bFromIndex;
7959         int length = Math.min(aLength, bLength);
7960         int i = ArraysSupport.mismatch(a, aFromIndex,
7961                                        b, bFromIndex,
7962                                        length);
7963         return (i < 0 && aLength != bLength) ? length : i;
7964     }
7965 
7966     // Mismatch int
7967 
7968     /**
7969      * Finds and returns the index of the first mismatch between two {@code int}
7970      * arrays, otherwise return -1 if no mismatch is found.  The index will be
7971      * in the range of 0 (inclusive) up to the length (inclusive) of the smaller
7972      * array.
7973      *
7974      * <p>If the two arrays share a common prefix then the returned index is the
7975      * length of the common prefix and it follows that there is a mismatch
7976      * between the two elements at that index within the respective arrays.
7977      * If one array is a proper prefix of the other then the returned index is
7978      * the length of the smaller array and it follows that the index is only
7979      * valid for the larger array.
7980      * Otherwise, there is no mismatch.
7981      *
7982      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
7983      * prefix of length {@code pl} if the following expression is true:
7984      * <pre>{@code
7985      *     pl >= 0 &&
7986      *     pl < Math.min(a.length, b.length) &&
7987      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
7988      *     a[pl] != b[pl]
7989      * }</pre>
7990      * Note that a common prefix length of {@code 0} indicates that the first
7991      * elements from each array mismatch.
7992      *
7993      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
7994      * prefix if the following expression is true:
7995      * <pre>{@code
7996      *     a.length != b.length &&
7997      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
7998      *                   b, 0, Math.min(a.length, b.length))
7999      * }</pre>
8000      *
8001      * @param a the first array to be tested for a mismatch
8002      * @param b the second array to be tested for a mismatch
8003      * @return the index of the first mismatch between the two arrays,
8004      *         otherwise {@code -1}.
8005      * @throws NullPointerException
8006      *         if either array is {@code null}
8007      * @since 9
8008      */
8009     public static int mismatch(int[] a, int[] b) {
8010         int length = Math.min(a.length, b.length); // Check null array refs
8011         if (a == b)
8012             return -1;
8013 
8014         int i = ArraysSupport.mismatch(a, b, length);
8015         return (i < 0 && a.length != b.length) ? length : i;
8016     }
8017 
8018     /**
8019      * Finds and returns the relative index of the first mismatch between two
8020      * {@code int} arrays over the specified ranges, otherwise return -1 if no
8021      * mismatch is found.  The index will be in the range of 0 (inclusive) up to
8022      * the length (inclusive) of the smaller range.
8023      *
8024      * <p>If the two arrays, over the specified ranges, share a common prefix
8025      * then the returned relative index is the length of the common prefix and
8026      * it follows that there is a mismatch between the two elements at that
8027      * relative index within the respective arrays.
8028      * If one array is a proper prefix of the other, over the specified ranges,
8029      * then the returned relative index is the length of the smaller range and
8030      * it follows that the relative index is only valid for the array with the
8031      * larger range.
8032      * Otherwise, there is no mismatch.
8033      *
8034      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8035      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8036      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
8037      * prefix of length {@code pl} if the following expression is true:
8038      * <pre>{@code
8039      *     pl >= 0 &&
8040      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
8041      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
8042      *     a[aFromIndex + pl] != b[bFromIndex + pl]
8043      * }</pre>
8044      * Note that a common prefix length of {@code 0} indicates that the first
8045      * elements from each array mismatch.
8046      *
8047      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8048      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8049      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
8050      * prefix if the following expression is true:
8051      * <pre>{@code
8052      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
8053      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
8054      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
8055      * }</pre>
8056      *
8057      * @param a the first array to be tested for a mismatch
8058      * @param aFromIndex the index (inclusive) of the first element in the
8059      *                   first array to be tested
8060      * @param aToIndex the index (exclusive) of the last element in the
8061      *                 first array to be tested
8062      * @param b the second array to be tested for a mismatch
8063      * @param bFromIndex the index (inclusive) of the first element in the
8064      *                   second array to be tested
8065      * @param bToIndex the index (exclusive) of the last element in the
8066      *                 second array to be tested
8067      * @return the relative index of the first mismatch between the two arrays
8068      *         over the specified ranges, otherwise {@code -1}.
8069      * @throws IllegalArgumentException
8070      *         if {@code aFromIndex > aToIndex} or
8071      *         if {@code bFromIndex > bToIndex}
8072      * @throws ArrayIndexOutOfBoundsException
8073      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
8074      *         if {@code bFromIndex < 0 or bToIndex > b.length}
8075      * @throws NullPointerException
8076      *         if either array is {@code null}
8077      * @since 9
8078      */
8079     public static int mismatch(int[] a, int aFromIndex, int aToIndex,
8080                                int[] b, int bFromIndex, int bToIndex) {
8081         rangeCheck(a.length, aFromIndex, aToIndex);
8082         rangeCheck(b.length, bFromIndex, bToIndex);
8083 
8084         int aLength = aToIndex - aFromIndex;
8085         int bLength = bToIndex - bFromIndex;
8086         int length = Math.min(aLength, bLength);
8087         int i = ArraysSupport.mismatch(a, aFromIndex,
8088                                        b, bFromIndex,
8089                                        length);
8090         return (i < 0 && aLength != bLength) ? length : i;
8091     }
8092 
8093     // Mismatch long
8094 
8095     /**
8096      * Finds and returns the index of the first mismatch between two {@code long}
8097      * arrays, otherwise return -1 if no mismatch is found.  The index will be
8098      * in the range of 0 (inclusive) up to the length (inclusive) of the smaller
8099      * array.
8100      *
8101      * <p>If the two arrays share a common prefix then the returned index is the
8102      * length of the common prefix and it follows that there is a mismatch
8103      * between the two elements at that index within the respective arrays.
8104      * If one array is a proper prefix of the other then the returned index is
8105      * the length of the smaller array and it follows that the index is only
8106      * valid for the larger array.
8107      * Otherwise, there is no mismatch.
8108      *
8109      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
8110      * prefix of length {@code pl} if the following expression is true:
8111      * <pre>{@code
8112      *     pl >= 0 &&
8113      *     pl < Math.min(a.length, b.length) &&
8114      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
8115      *     a[pl] != b[pl]
8116      * }</pre>
8117      * Note that a common prefix length of {@code 0} indicates that the first
8118      * elements from each array mismatch.
8119      *
8120      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
8121      * prefix if the following expression is true:
8122      * <pre>{@code
8123      *     a.length != b.length &&
8124      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
8125      *                   b, 0, Math.min(a.length, b.length))
8126      * }</pre>
8127      *
8128      * @param a the first array to be tested for a mismatch
8129      * @param b the second array to be tested for a mismatch
8130      * @return the index of the first mismatch between the two arrays,
8131      *         otherwise {@code -1}.
8132      * @throws NullPointerException
8133      *         if either array is {@code null}
8134      * @since 9
8135      */
8136     public static int mismatch(long[] a, long[] b) {
8137         int length = Math.min(a.length, b.length); // Check null array refs
8138         if (a == b)
8139             return -1;
8140 
8141         int i = ArraysSupport.mismatch(a, b, length);
8142         return (i < 0 && a.length != b.length) ? length : i;
8143     }
8144 
8145     /**
8146      * Finds and returns the relative index of the first mismatch between two
8147      * {@code long} arrays over the specified ranges, otherwise return -1 if no
8148      * mismatch is found.  The index will be in the range of 0 (inclusive) up to
8149      * the length (inclusive) of the smaller range.
8150      *
8151      * <p>If the two arrays, over the specified ranges, share a common prefix
8152      * then the returned relative index is the length of the common prefix and
8153      * it follows that there is a mismatch between the two elements at that
8154      * relative index within the respective arrays.
8155      * If one array is a proper prefix of the other, over the specified ranges,
8156      * then the returned relative index is the length of the smaller range and
8157      * it follows that the relative index is only valid for the array with the
8158      * larger range.
8159      * Otherwise, there is no mismatch.
8160      *
8161      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8162      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8163      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
8164      * prefix of length {@code pl} if the following expression is true:
8165      * <pre>{@code
8166      *     pl >= 0 &&
8167      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
8168      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
8169      *     a[aFromIndex + pl] != b[bFromIndex + pl]
8170      * }</pre>
8171      * Note that a common prefix length of {@code 0} indicates that the first
8172      * elements from each array mismatch.
8173      *
8174      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8175      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8176      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
8177      * prefix if the following expression is true:
8178      * <pre>{@code
8179      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
8180      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
8181      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
8182      * }</pre>
8183      *
8184      * @param a the first array to be tested for a mismatch
8185      * @param aFromIndex the index (inclusive) of the first element in the
8186      *                   first array to be tested
8187      * @param aToIndex the index (exclusive) of the last element in the
8188      *                 first array to be tested
8189      * @param b the second array to be tested for a mismatch
8190      * @param bFromIndex the index (inclusive) of the first element in the
8191      *                   second array to be tested
8192      * @param bToIndex the index (exclusive) of the last element in the
8193      *                 second array to be tested
8194      * @return the relative index of the first mismatch between the two arrays
8195      *         over the specified ranges, otherwise {@code -1}.
8196      * @throws IllegalArgumentException
8197      *         if {@code aFromIndex > aToIndex} or
8198      *         if {@code bFromIndex > bToIndex}
8199      * @throws ArrayIndexOutOfBoundsException
8200      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
8201      *         if {@code bFromIndex < 0 or bToIndex > b.length}
8202      * @throws NullPointerException
8203      *         if either array is {@code null}
8204      * @since 9
8205      */
8206     public static int mismatch(long[] a, int aFromIndex, int aToIndex,
8207                                long[] b, int bFromIndex, int bToIndex) {
8208         rangeCheck(a.length, aFromIndex, aToIndex);
8209         rangeCheck(b.length, bFromIndex, bToIndex);
8210 
8211         int aLength = aToIndex - aFromIndex;
8212         int bLength = bToIndex - bFromIndex;
8213         int length = Math.min(aLength, bLength);
8214         int i = ArraysSupport.mismatch(a, aFromIndex,
8215                                        b, bFromIndex,
8216                                        length);
8217         return (i < 0 && aLength != bLength) ? length : i;
8218     }
8219 
8220     // Mismatch float
8221 
8222     /**
8223      * Finds and returns the index of the first mismatch between two {@code float}
8224      * arrays, otherwise return -1 if no mismatch is found.  The index will be
8225      * in the range of 0 (inclusive) up to the length (inclusive) of the smaller
8226      * array.
8227      *
8228      * <p>If the two arrays share a common prefix then the returned index is the
8229      * length of the common prefix and it follows that there is a mismatch
8230      * between the two elements at that index within the respective arrays.
8231      * If one array is a proper prefix of the other then the returned index is
8232      * the length of the smaller array and it follows that the index is only
8233      * valid for the larger array.
8234      * Otherwise, there is no mismatch.
8235      *
8236      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
8237      * prefix of length {@code pl} if the following expression is true:
8238      * <pre>{@code
8239      *     pl >= 0 &&
8240      *     pl < Math.min(a.length, b.length) &&
8241      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
8242      *     Float.compare(a[pl], b[pl]) != 0
8243      * }</pre>
8244      * Note that a common prefix length of {@code 0} indicates that the first
8245      * elements from each array mismatch.
8246      *
8247      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
8248      * prefix if the following expression is true:
8249      * <pre>{@code
8250      *     a.length != b.length &&
8251      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
8252      *                   b, 0, Math.min(a.length, b.length))
8253      * }</pre>
8254      *
8255      * @param a the first array to be tested for a mismatch
8256      * @param b the second array to be tested for a mismatch
8257      * @return the index of the first mismatch between the two arrays,
8258      *         otherwise {@code -1}.
8259      * @throws NullPointerException
8260      *         if either array is {@code null}
8261      * @since 9
8262      */
8263     public static int mismatch(float[] a, float[] b) {
8264         int length = Math.min(a.length, b.length); // Check null array refs
8265         if (a == b)
8266             return -1;
8267 
8268         int i = ArraysSupport.mismatch(a, b, length);
8269         return (i < 0 && a.length != b.length) ? length : i;
8270     }
8271 
8272     /**
8273      * Finds and returns the relative index of the first mismatch between two
8274      * {@code float} arrays over the specified ranges, otherwise return -1 if no
8275      * mismatch is found.  The index will be in the range of 0 (inclusive) up to
8276      * the length (inclusive) of the smaller range.
8277      *
8278      * <p>If the two arrays, over the specified ranges, share a common prefix
8279      * then the returned relative index is the length of the common prefix and
8280      * it follows that there is a mismatch between the two elements at that
8281      * relative index within the respective arrays.
8282      * If one array is a proper prefix of the other, over the specified ranges,
8283      * then the returned relative index is the length of the smaller range and
8284      * it follows that the relative index is only valid for the array with the
8285      * larger range.
8286      * Otherwise, there is no mismatch.
8287      *
8288      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8289      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8290      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
8291      * prefix of length {@code pl} if the following expression is true:
8292      * <pre>{@code
8293      *     pl >= 0 &&
8294      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
8295      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
8296      *     Float.compare(a[aFromIndex + pl], b[bFromIndex + pl]) != 0
8297      * }</pre>
8298      * Note that a common prefix length of {@code 0} indicates that the first
8299      * elements from each array mismatch.
8300      *
8301      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8302      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8303      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
8304      * prefix if the following expression is true:
8305      * <pre>{@code
8306      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
8307      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
8308      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
8309      * }</pre>
8310      *
8311      * @param a the first array to be tested for a mismatch
8312      * @param aFromIndex the index (inclusive) of the first element in the
8313      *                   first array to be tested
8314      * @param aToIndex the index (exclusive) of the last element in the
8315      *                 first array to be tested
8316      * @param b the second array to be tested for a mismatch
8317      * @param bFromIndex the index (inclusive) of the first element in the
8318      *                   second array to be tested
8319      * @param bToIndex the index (exclusive) of the last element in the
8320      *                 second array to be tested
8321      * @return the relative index of the first mismatch between the two arrays
8322      *         over the specified ranges, otherwise {@code -1}.
8323      * @throws IllegalArgumentException
8324      *         if {@code aFromIndex > aToIndex} or
8325      *         if {@code bFromIndex > bToIndex}
8326      * @throws ArrayIndexOutOfBoundsException
8327      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
8328      *         if {@code bFromIndex < 0 or bToIndex > b.length}
8329      * @throws NullPointerException
8330      *         if either array is {@code null}
8331      * @since 9
8332      */
8333     public static int mismatch(float[] a, int aFromIndex, int aToIndex,
8334                                float[] b, int bFromIndex, int bToIndex) {
8335         rangeCheck(a.length, aFromIndex, aToIndex);
8336         rangeCheck(b.length, bFromIndex, bToIndex);
8337 
8338         int aLength = aToIndex - aFromIndex;
8339         int bLength = bToIndex - bFromIndex;
8340         int length = Math.min(aLength, bLength);
8341         int i = ArraysSupport.mismatch(a, aFromIndex,
8342                                        b, bFromIndex,
8343                                        length);
8344         return (i < 0 && aLength != bLength) ? length : i;
8345     }
8346 
8347     // Mismatch double
8348 
8349     /**
8350      * Finds and returns the index of the first mismatch between two
8351      * {@code double} arrays, otherwise return -1 if no mismatch is found.  The
8352      * index will be in the range of 0 (inclusive) up to the length (inclusive)
8353      * of the smaller array.
8354      *
8355      * <p>If the two arrays share a common prefix then the returned index is the
8356      * length of the common prefix and it follows that there is a mismatch
8357      * between the two elements at that index within the respective arrays.
8358      * If one array is a proper prefix of the other then the returned index is
8359      * the length of the smaller array and it follows that the index is only
8360      * valid for the larger array.
8361      * Otherwise, there is no mismatch.
8362      *
8363      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
8364      * prefix of length {@code pl} if the following expression is true:
8365      * <pre>{@code
8366      *     pl >= 0 &&
8367      *     pl < Math.min(a.length, b.length) &&
8368      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
8369      *     Double.compare(a[pl], b[pl]) != 0
8370      * }</pre>
8371      * Note that a common prefix length of {@code 0} indicates that the first
8372      * elements from each array mismatch.
8373      *
8374      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
8375      * prefix if the following expression is true:
8376      * <pre>{@code
8377      *     a.length != b.length &&
8378      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
8379      *                   b, 0, Math.min(a.length, b.length))
8380      * }</pre>
8381      *
8382      * @param a the first array to be tested for a mismatch
8383      * @param b the second array to be tested for a mismatch
8384      * @return the index of the first mismatch between the two arrays,
8385      *         otherwise {@code -1}.
8386      * @throws NullPointerException
8387      *         if either array is {@code null}
8388      * @since 9
8389      */
8390     public static int mismatch(double[] a, double[] b) {
8391         int length = Math.min(a.length, b.length); // Check null array refs
8392         if (a == b)
8393             return -1;
8394 
8395         int i = ArraysSupport.mismatch(a, b, length);
8396         return (i < 0 && a.length != b.length) ? length : i;
8397     }
8398 
8399     /**
8400      * Finds and returns the relative index of the first mismatch between two
8401      * {@code double} arrays over the specified ranges, otherwise return -1 if
8402      * no mismatch is found.  The index will be in the range of 0 (inclusive) up
8403      * to the length (inclusive) of the smaller range.
8404      *
8405      * <p>If the two arrays, over the specified ranges, share a common prefix
8406      * then the returned relative index is the length of the common prefix and
8407      * it follows that there is a mismatch between the two elements at that
8408      * relative index within the respective arrays.
8409      * If one array is a proper prefix of the other, over the specified ranges,
8410      * then the returned relative index is the length of the smaller range and
8411      * it follows that the relative index is only valid for the array with the
8412      * larger range.
8413      * Otherwise, there is no mismatch.
8414      *
8415      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8416      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8417      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
8418      * prefix of length {@code pl} if the following expression is true:
8419      * <pre>{@code
8420      *     pl >= 0 &&
8421      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
8422      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
8423      *     Double.compare(a[aFromIndex + pl], b[bFromIndex + pl]) != 0
8424      * }</pre>
8425      * Note that a common prefix length of {@code 0} indicates that the first
8426      * elements from each array mismatch.
8427      *
8428      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8429      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8430      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
8431      * prefix if the following expression is true:
8432      * <pre>{@code
8433      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
8434      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
8435      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
8436      * }</pre>
8437      *
8438      * @param a the first array to be tested for a mismatch
8439      * @param aFromIndex the index (inclusive) of the first element in the
8440      *                   first array to be tested
8441      * @param aToIndex the index (exclusive) of the last element in the
8442      *                 first array to be tested
8443      * @param b the second array to be tested for a mismatch
8444      * @param bFromIndex the index (inclusive) of the first element in the
8445      *                   second array to be tested
8446      * @param bToIndex the index (exclusive) of the last element in the
8447      *                 second array to be tested
8448      * @return the relative index of the first mismatch between the two arrays
8449      *         over the specified ranges, otherwise {@code -1}.
8450      * @throws IllegalArgumentException
8451      *         if {@code aFromIndex > aToIndex} or
8452      *         if {@code bFromIndex > bToIndex}
8453      * @throws ArrayIndexOutOfBoundsException
8454      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
8455      *         if {@code bFromIndex < 0 or bToIndex > b.length}
8456      * @throws NullPointerException
8457      *         if either array is {@code null}
8458      * @since 9
8459      */
8460     public static int mismatch(double[] a, int aFromIndex, int aToIndex,
8461                                double[] b, int bFromIndex, int bToIndex) {
8462         rangeCheck(a.length, aFromIndex, aToIndex);
8463         rangeCheck(b.length, bFromIndex, bToIndex);
8464 
8465         int aLength = aToIndex - aFromIndex;
8466         int bLength = bToIndex - bFromIndex;
8467         int length = Math.min(aLength, bLength);
8468         int i = ArraysSupport.mismatch(a, aFromIndex,
8469                                        b, bFromIndex,
8470                                        length);
8471         return (i < 0 && aLength != bLength) ? length : i;
8472     }
8473 
8474     // Mismatch objects
8475 
8476     /**
8477      * Finds and returns the index of the first mismatch between two
8478      * {@code Object} arrays, otherwise return -1 if no mismatch is found.  The
8479      * index will be in the range of 0 (inclusive) up to the length (inclusive)
8480      * of the smaller array.
8481      *
8482      * <p>If the two arrays share a common prefix then the returned index is the
8483      * length of the common prefix and it follows that there is a mismatch
8484      * between the two elements at that index within the respective arrays.
8485      * If one array is a proper prefix of the other then the returned index is
8486      * the length of the smaller array and it follows that the index is only
8487      * valid for the larger array.
8488      * Otherwise, there is no mismatch.
8489      *
8490      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
8491      * prefix of length {@code pl} if the following expression is true:
8492      * <pre>{@code
8493      *     pl >= 0 &&
8494      *     pl < Math.min(a.length, b.length) &&
8495      *     Arrays.equals(a, 0, pl, b, 0, pl) &&
8496      *     !Objects.equals(a[pl], b[pl])
8497      * }</pre>
8498      * Note that a common prefix length of {@code 0} indicates that the first
8499      * elements from each array mismatch.
8500      *
8501      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
8502      * prefix if the following expression is true:
8503      * <pre>{@code
8504      *     a.length != b.length &&
8505      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
8506      *                   b, 0, Math.min(a.length, b.length))
8507      * }</pre>
8508      *
8509      * @param a the first array to be tested for a mismatch
8510      * @param b the second array to be tested for a mismatch
8511      * @return the index of the first mismatch between the two arrays,
8512      *         otherwise {@code -1}.
8513      * @throws NullPointerException
8514      *         if either array is {@code null}
8515      * @since 9
8516      */
8517     public static int mismatch(Object[] a, Object[] b) {
8518         int length = Math.min(a.length, b.length); // Check null array refs
8519         if (a == b)
8520             return -1;
8521 
8522         for (int i = 0; i < length; i++) {
8523             if (!Objects.equals(a[i], b[i]))
8524                 return i;
8525         }
8526 
8527         return a.length != b.length ? length : -1;
8528     }
8529 
8530     /**
8531      * Finds and returns the relative index of the first mismatch between two
8532      * {@code Object} arrays over the specified ranges, otherwise return -1 if
8533      * no mismatch is found.  The index will be in the range of 0 (inclusive) up
8534      * to the length (inclusive) of the smaller range.
8535      *
8536      * <p>If the two arrays, over the specified ranges, share a common prefix
8537      * then the returned relative index is the length of the common prefix and
8538      * it follows that there is a mismatch between the two elements at that
8539      * relative index within the respective arrays.
8540      * If one array is a proper prefix of the other, over the specified ranges,
8541      * then the returned relative index is the length of the smaller range and
8542      * it follows that the relative index is only valid for the array with the
8543      * larger range.
8544      * Otherwise, there is no mismatch.
8545      *
8546      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8547      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8548      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
8549      * prefix of length {@code pl} if the following expression is true:
8550      * <pre>{@code
8551      *     pl >= 0 &&
8552      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
8553      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl) &&
8554      *     !Objects.equals(a[aFromIndex + pl], b[bFromIndex + pl])
8555      * }</pre>
8556      * Note that a common prefix length of {@code 0} indicates that the first
8557      * elements from each array mismatch.
8558      *
8559      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8560      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8561      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
8562      * prefix if the following expression is true:
8563      * <pre>{@code
8564      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
8565      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
8566      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex))
8567      * }</pre>
8568      *
8569      * @param a the first array to be tested for a mismatch
8570      * @param aFromIndex the index (inclusive) of the first element in the
8571      *                   first array to be tested
8572      * @param aToIndex the index (exclusive) of the last element in the
8573      *                 first array to be tested
8574      * @param b the second array to be tested for a mismatch
8575      * @param bFromIndex the index (inclusive) of the first element in the
8576      *                   second array to be tested
8577      * @param bToIndex the index (exclusive) of the last element in the
8578      *                 second array to be tested
8579      * @return the relative index of the first mismatch between the two arrays
8580      *         over the specified ranges, otherwise {@code -1}.
8581      * @throws IllegalArgumentException
8582      *         if {@code aFromIndex > aToIndex} or
8583      *         if {@code bFromIndex > bToIndex}
8584      * @throws ArrayIndexOutOfBoundsException
8585      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
8586      *         if {@code bFromIndex < 0 or bToIndex > b.length}
8587      * @throws NullPointerException
8588      *         if either array is {@code null}
8589      * @since 9
8590      */
8591     public static int mismatch(
8592             Object[] a, int aFromIndex, int aToIndex,
8593             Object[] b, int bFromIndex, int bToIndex) {
8594         rangeCheck(a.length, aFromIndex, aToIndex);
8595         rangeCheck(b.length, bFromIndex, bToIndex);
8596 
8597         int aLength = aToIndex - aFromIndex;
8598         int bLength = bToIndex - bFromIndex;
8599         int length = Math.min(aLength, bLength);
8600         for (int i = 0; i < length; i++) {
8601             if (!Objects.equals(a[aFromIndex++], b[bFromIndex++]))
8602                 return i;
8603         }
8604 
8605         return aLength != bLength ? length : -1;
8606     }
8607 
8608     /**
8609      * Finds and returns the index of the first mismatch between two
8610      * {@code Object} arrays, otherwise return -1 if no mismatch is found.
8611      * The index will be in the range of 0 (inclusive) up to the length
8612      * (inclusive) of the smaller array.
8613      *
8614      * <p>The specified comparator is used to determine if two array elements
8615      * from the each array are not equal.
8616      *
8617      * <p>If the two arrays share a common prefix then the returned index is the
8618      * length of the common prefix and it follows that there is a mismatch
8619      * between the two elements at that index within the respective arrays.
8620      * If one array is a proper prefix of the other then the returned index is
8621      * the length of the smaller array and it follows that the index is only
8622      * valid for the larger array.
8623      * Otherwise, there is no mismatch.
8624      *
8625      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a common
8626      * prefix of length {@code pl} if the following expression is true:
8627      * <pre>{@code
8628      *     pl >= 0 &&
8629      *     pl < Math.min(a.length, b.length) &&
8630      *     Arrays.equals(a, 0, pl, b, 0, pl, cmp)
8631      *     cmp.compare(a[pl], b[pl]) != 0
8632      * }</pre>
8633      * Note that a common prefix length of {@code 0} indicates that the first
8634      * elements from each array mismatch.
8635      *
8636      * <p>Two non-{@code null} arrays, {@code a} and {@code b}, share a proper
8637      * prefix if the following expression is true:
8638      * <pre>{@code
8639      *     a.length != b.length &&
8640      *     Arrays.equals(a, 0, Math.min(a.length, b.length),
8641      *                   b, 0, Math.min(a.length, b.length),
8642      *                   cmp)
8643      * }</pre>
8644      *
8645      * @param a the first array to be tested for a mismatch
8646      * @param b the second array to be tested for a mismatch
8647      * @param cmp the comparator to compare array elements
8648      * @param <T> the type of array elements
8649      * @return the index of the first mismatch between the two arrays,
8650      *         otherwise {@code -1}.
8651      * @throws NullPointerException
8652      *         if either array or the comparator is {@code null}
8653      * @since 9
8654      */
8655     public static <T> int mismatch(T[] a, T[] b, Comparator<? super T> cmp) {
8656         Objects.requireNonNull(cmp);
8657         int length = Math.min(a.length, b.length); // Check null array refs
8658         if (a == b)
8659             return -1;
8660 
8661         for (int i = 0; i < length; i++) {
8662             T oa = a[i];
8663             T ob = b[i];
8664             if (oa != ob) {
8665                 // Null-value comparison is deferred to the comparator
8666                 int v = cmp.compare(oa, ob);
8667                 if (v != 0) {
8668                     return i;
8669                 }
8670             }
8671         }
8672 
8673         return a.length != b.length ? length : -1;
8674     }
8675 
8676     /**
8677      * Finds and returns the relative index of the first mismatch between two
8678      * {@code Object} arrays over the specified ranges, otherwise return -1 if
8679      * no mismatch is found.  The index will be in the range of 0 (inclusive) up
8680      * to the length (inclusive) of the smaller range.
8681      *
8682      * <p>If the two arrays, over the specified ranges, share a common prefix
8683      * then the returned relative index is the length of the common prefix and
8684      * it follows that there is a mismatch between the two elements at that
8685      * relative index within the respective arrays.
8686      * If one array is a proper prefix of the other, over the specified ranges,
8687      * then the returned relative index is the length of the smaller range and
8688      * it follows that the relative index is only valid for the array with the
8689      * larger range.
8690      * Otherwise, there is no mismatch.
8691      *
8692      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8693      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8694      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a common
8695      * prefix of length {@code pl} if the following expression is true:
8696      * <pre>{@code
8697      *     pl >= 0 &&
8698      *     pl < Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex) &&
8699      *     Arrays.equals(a, aFromIndex, aFromIndex + pl, b, bFromIndex, bFromIndex + pl, cmp) &&
8700      *     cmp.compare(a[aFromIndex + pl], b[bFromIndex + pl]) != 0
8701      * }</pre>
8702      * Note that a common prefix length of {@code 0} indicates that the first
8703      * elements from each array mismatch.
8704      *
8705      * <p>Two non-{@code null} arrays, {@code a} and {@code b} with specified
8706      * ranges [{@code aFromIndex}, {@code aToIndex}) and
8707      * [{@code bFromIndex}, {@code bToIndex}) respectively, share a proper
8708      * prefix if the following expression is true:
8709      * <pre>{@code
8710      *     (aToIndex - aFromIndex) != (bToIndex - bFromIndex) &&
8711      *     Arrays.equals(a, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
8712      *                   b, 0, Math.min(aToIndex - aFromIndex, bToIndex - bFromIndex),
8713      *                   cmp)
8714      * }</pre>
8715      *
8716      * @param a the first array to be tested for a mismatch
8717      * @param aFromIndex the index (inclusive) of the first element in the
8718      *                   first array to be tested
8719      * @param aToIndex the index (exclusive) of the last element in the
8720      *                 first array to be tested
8721      * @param b the second array to be tested for a mismatch
8722      * @param bFromIndex the index (inclusive) of the first element in the
8723      *                   second array to be tested
8724      * @param bToIndex the index (exclusive) of the last element in the
8725      *                 second array to be tested
8726      * @param cmp the comparator to compare array elements
8727      * @param <T> the type of array elements
8728      * @return the relative index of the first mismatch between the two arrays
8729      *         over the specified ranges, otherwise {@code -1}.
8730      * @throws IllegalArgumentException
8731      *         if {@code aFromIndex > aToIndex} or
8732      *         if {@code bFromIndex > bToIndex}
8733      * @throws ArrayIndexOutOfBoundsException
8734      *         if {@code aFromIndex < 0 or aToIndex > a.length} or
8735      *         if {@code bFromIndex < 0 or bToIndex > b.length}
8736      * @throws NullPointerException
8737      *         if either array or the comparator is {@code null}
8738      * @since 9
8739      */
8740     public static <T> int mismatch(
8741             T[] a, int aFromIndex, int aToIndex,
8742             T[] b, int bFromIndex, int bToIndex,
8743             Comparator<? super T> cmp) {
8744         Objects.requireNonNull(cmp);
8745         rangeCheck(a.length, aFromIndex, aToIndex);
8746         rangeCheck(b.length, bFromIndex, bToIndex);
8747 
8748         int aLength = aToIndex - aFromIndex;
8749         int bLength = bToIndex - bFromIndex;
8750         int length = Math.min(aLength, bLength);
8751         for (int i = 0; i < length; i++) {
8752             T oa = a[aFromIndex++];
8753             T ob = b[bFromIndex++];
8754             if (oa != ob) {
8755                 // Null-value comparison is deferred to the comparator
8756                 int v = cmp.compare(oa, ob);
8757                 if (v != 0) {
8758                     return i;
8759                 }
8760             }
8761         }
8762 
8763         return aLength != bLength ? length : -1;
8764     }
8765 }