public final class Objects extends Object
static utility methods for operating
 on objects.  These utilities include null-safe or null-tolerant methods for computing the hash code of an object,
 returning a string for an object, and comparing two objects.| Modifier and Type | Method and Description | 
|---|---|
| static <T> int | compare(T a,
       T b,
       Comparator<? super T> c)Returns 0 if the arguments are identical and  c.compare(a, b)otherwise. | 
| static boolean | deepEquals(Object a,
          Object b)Returns  trueif the arguments are deeply equal to each other
 andfalseotherwise. | 
| static boolean | equals(Object a,
      Object b)Returns  trueif the arguments are equal to each other
 andfalseotherwise. | 
| static int | hash(Object... values)Generates a hash code for a sequence of input values. | 
| static int | hashCode(Object o)Returns the hash code of a non- nullargument and 0 for
 anullargument. | 
| static boolean | isNull(Object obj)Returns  trueif the provided reference isnullotherwise
 returnsfalse. | 
| static boolean | nonNull(Object obj)Returns  trueif the provided reference is non-nullotherwise returnsfalse. | 
| static <T> T | requireNonNull(T obj)Checks that the specified object reference is not  null. | 
| static <T> T | requireNonNull(T obj,
              String message)Checks that the specified object reference is not  nulland
 throws a customizedNullPointerExceptionif it is. | 
| static <T> T | requireNonNull(T obj,
              Supplier<String> messageSupplier)Checks that the specified object reference is not  nulland
 throws a customizedNullPointerExceptionif it is. | 
| static String | toString(Object o)Returns the result of calling  toStringfor a non-nullargument and"null"for anullargument. | 
| static String | toString(Object o,
        String nullDefault)Returns the result of calling  toStringon the first
 argument if the first argument is notnulland returns
 the second argument otherwise. | 
public static boolean equals(Object a, Object b)
true if the arguments are equal to each other
 and false otherwise.
 Consequently, if both arguments are null, true
 is returned and if exactly one argument is null, false is returned.  Otherwise, equality is determined by using
 the equals method of the first
 argument.a - an objectb - an object to be compared with a for equalitytrue if the arguments are equal to each other
 and false otherwiseObject.equals(Object)public static boolean deepEquals(Object a, Object b)
true if the arguments are deeply equal to each other
 and false otherwise.
 Two null values are deeply equal.  If both arguments are
 arrays, the algorithm in Arrays.deepEquals is used to determine equality.
 Otherwise, equality is determined by using the equals method of the first argument.a - an objectb - an object to be compared with a for deep equalitytrue if the arguments are deeply equal to each other
 and false otherwiseArrays.deepEquals(Object[], Object[]), 
equals(Object, Object)public static int hashCode(Object o)
null argument and 0 for
 a null argument.o - an objectnull argument and 0 for
 a null argumentObject.hashCode()public static int hash(Object... values)
Arrays.hashCode(Object[]).
 This method is useful for implementing Object.hashCode() on objects containing multiple fields. For
 example, if an object that has three fields, x, y, and z, one could write:
 
 @Override public int hashCode() {
     return Objects.hash(x, y, z);
 }
 hashCode(Object).values - the values to be hashedArrays.hashCode(Object[]), 
List.hashCode()public static String toString(Object o)
toString for a non-null argument and "null" for a null argument.o - an objecttoString for a non-null argument and "null" for a null argumentObject.toString(), 
String.valueOf(Object)public static String toString(Object o, String nullDefault)
toString on the first
 argument if the first argument is not null and returns
 the second argument otherwise.o - an objectnullDefault - string to return if the first argument is
        nulltoString on the first
 argument if it is not null and the second argument
 otherwise.toString(Object)public static <T> int compare(T a,
                              T b,
                              Comparator<? super T> c)
c.compare(a, b) otherwise.
 Consequently, if both arguments are null 0
 is returned.
 Note that if one of the arguments is null, a NullPointerException may or may not be thrown depending on
 what ordering policy, if any, the Comparator
 chooses to have for null values.
T - the type of the objects being compareda - an objectb - an object to be compared with ac - the Comparator to compare the first two argumentsc.compare(a, b) otherwise.Comparable, 
Comparatorpublic static <T> T requireNonNull(T obj)
null. This
 method is designed primarily for doing parameter validation in methods
 and constructors, as demonstrated below:
 
 public Foo(Bar bar) {
     this.bar = Objects.requireNonNull(bar);
 }
 T - the type of the referenceobj - the object reference to check for nullityobj if not nullNullPointerException - if obj is nullpublic static <T> T requireNonNull(T obj,
                                   String message)
null and
 throws a customized NullPointerException if it is. This method
 is designed primarily for doing parameter validation in methods and
 constructors with multiple parameters, as demonstrated below:
 
 public Foo(Bar bar, Baz baz) {
     this.bar = Objects.requireNonNull(bar, "bar must not be null");
     this.baz = Objects.requireNonNull(baz, "baz must not be null");
 }
 T - the type of the referenceobj - the object reference to check for nullitymessage - detail message to be used in the event that a NullPointerException is thrownobj if not nullNullPointerException - if obj is nullpublic static boolean isNull(Object obj)
true if the provided reference is null otherwise
 returns false.public static boolean nonNull(Object obj)
true if the provided reference is non-null
 otherwise returns false.public static <T> T requireNonNull(T obj,
                                   Supplier<String> messageSupplier)
null and
 throws a customized NullPointerException if it is.
 Unlike the method requireNonNull(Object, String),
 this method allows creation of the message to be deferred until
 after the null check is made. While this may confer a
 performance advantage in the non-null case, when deciding to
 call this method care should be taken that the costs of
 creating the message supplier are less than the cost of just
 creating the string message directly.
T - the type of the referenceobj - the object reference to check for nullitymessageSupplier - supplier of the detail message to be
 used in the event that a NullPointerException is thrownobj if not nullNullPointerException - if obj is null Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2019, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.