Arrays.DeepHashCode(Object[]) Method
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Returns a hash code based on the "deep contents" of the specified array.
[Android.Runtime.Register("deepHashCode", "([Ljava/lang/Object;)I", "")]
public static int DeepHashCode (Java.Lang.Object[]? a);
[<Android.Runtime.Register("deepHashCode", "([Ljava/lang/Object;)I", "")>]
static member DeepHashCode : Java.Lang.Object[] -> int
Parameters
- a
- Object[]
the array whose deep-content-based hash code to compute
Returns
a deep-content-based hash code for a
- Attributes
Remarks
Returns a hash code based on the "deep contents" of the specified array. If the array contains other arrays as elements, the hash code is based on their contents and so on, ad infinitum. It is therefore unacceptable to invoke this method on an array that contains itself as an element, either directly or indirectly through one or more levels of arrays. The behavior of such an invocation is undefined.
For any two arrays a
and b
such that Arrays.deepEquals(a, b)
, it is also the case that Arrays.deepHashCode(a) == Arrays.deepHashCode(b)
.
The computation of the value returned by this method is similar to that of the value returned by List#hashCode()
on a list containing the same elements as a
in the same order, with one difference: If an element e
of a
is itself an array, its hash code is computed not by calling e.hashCode()
, but as by calling the appropriate overloading of Arrays.hashCode(e)
if e
is an array of a primitive type, or as by calling Arrays.deepHashCode(e)
recursively if e
is an array of a reference type. If a
is null
, this method returns 0.
Added in 1.5.
Java documentation for java.util.Arrays.deepHashCode(java.lang.Object[])
.
Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.