diff --git a/src/java.base/share/classes/java/lang/Double.java b/src/java.base/share/classes/java/lang/Double.java index 9d57960d0c7..dbb8770f485 100644 --- a/src/java.base/share/classes/java/lang/Double.java +++ b/src/java.base/share/classes/java/lang/Double.java @@ -877,8 +877,7 @@ public final class Double extends Number * @since 1.8 */ public static int hashCode(double value) { - long bits = doubleToLongBits(value); - return (int)(bits ^ (bits >>> 32)); + return Long.hashCode(doubleToLongBits(value)); } /** diff --git a/src/java.base/share/classes/java/time/LocalTime.java b/src/java.base/share/classes/java/time/LocalTime.java index 1b82bda5154..b89c72d1713 100644 --- a/src/java.base/share/classes/java/time/LocalTime.java +++ b/src/java.base/share/classes/java/time/LocalTime.java @@ -1596,8 +1596,7 @@ public final class LocalTime */ @Override public int hashCode() { - long nod = toNanoOfDay(); - return (int) (nod ^ (nod >>> 32)); + return Long.hashCode(toNanoOfDay()); } //----------------------------------------------------------------------- diff --git a/src/java.base/share/classes/java/time/temporal/ValueRange.java b/src/java.base/share/classes/java/time/temporal/ValueRange.java index b17f56ccd4d..78a13420877 100644 --- a/src/java.base/share/classes/java/time/temporal/ValueRange.java +++ b/src/java.base/share/classes/java/time/temporal/ValueRange.java @@ -410,7 +410,7 @@ public final class ValueRange implements Serializable { long hash = minSmallest + (minLargest << 16) + (minLargest >> 48) + (maxSmallest << 32) + (maxSmallest >> 32) + (maxLargest << 48) + (maxLargest >> 16); - return (int) (hash ^ (hash >>> 32)); + return Long.hashCode(hash); } //----------------------------------------------------------------------- diff --git a/src/java.desktop/macosx/classes/apple/laf/JRSUIConstants.java b/src/java.desktop/macosx/classes/apple/laf/JRSUIConstants.java index 175af75f73d..1e98cb19ba4 100644 --- a/src/java.desktop/macosx/classes/apple/laf/JRSUIConstants.java +++ b/src/java.desktop/macosx/classes/apple/laf/JRSUIConstants.java @@ -111,8 +111,7 @@ public final class JRSUIConstants { } public int hashCode() { - final long bits = Double.doubleToLongBits(doubleValue); - return (int)(bits ^ (bits >>> 32)); + return Double.hashCode(doubleValue); } public String toString() { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/dv/xs/DoubleDV.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/dv/xs/DoubleDV.java index 3c50032b567..a9f58fc8b0c 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/dv/xs/DoubleDV.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/dv/xs/DoubleDV.java @@ -123,8 +123,7 @@ public class DoubleDV extends TypeValidator { if (value == 0d) { return 0; } - long v = Double.doubleToLongBits(value); - return (int) (v ^ (v >>> 32)); + return Double.hashCode(value); } // NOTE: 0.0 is equal but not identical to -0.0 diff --git a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/Selector.java b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/Selector.java index 412efa6e5d7..9d540847148 100644 --- a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/Selector.java +++ b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/Selector.java @@ -276,7 +276,7 @@ class Selector { @Override public int hashCode() { - return (int) (asBits() ^ (asBits() >>> 32)); + return Long.hashCode(asBits()); } /**