2012-05-11 23:43:27 +00:00
|
|
|
/* Copyright (c) 2008-2011, Avian Contributors
|
2008-02-19 18:06:52 +00:00
|
|
|
|
|
|
|
Permission to use, copy, modify, and/or distribute this software
|
|
|
|
for any purpose with or without fee is hereby granted, provided
|
|
|
|
that the above copyright notice and this permission notice appear
|
|
|
|
in all copies.
|
|
|
|
|
|
|
|
There is NO WARRANTY for this software. See license.txt for
|
|
|
|
details. */
|
|
|
|
|
2007-07-20 03:18:25 +00:00
|
|
|
package java.lang;
|
|
|
|
|
2007-07-21 17:50:26 +00:00
|
|
|
public final class Float extends Number {
|
2007-07-28 16:55:24 +00:00
|
|
|
public static final Class TYPE = Class.forCanonicalName("F");
|
2011-12-28 22:52:53 +00:00
|
|
|
private static final int EXP_BIT_MASK = 0x7F800000;
|
|
|
|
private static final int SIGNIF_BIT_MASK = 0x007FFFFF;
|
|
|
|
|
|
|
|
private final float value;
|
2007-07-20 03:18:25 +00:00
|
|
|
|
2008-02-28 15:35:16 +00:00
|
|
|
public Float(String value) {
|
|
|
|
this.value = parseFloat(value);
|
|
|
|
}
|
|
|
|
|
2007-07-20 03:18:25 +00:00
|
|
|
public Float(float value) {
|
|
|
|
this.value = value;
|
|
|
|
}
|
|
|
|
|
2007-08-13 00:50:25 +00:00
|
|
|
public static Float valueOf(float value) {
|
|
|
|
return new Float(value);
|
|
|
|
}
|
|
|
|
|
2008-02-28 15:35:16 +00:00
|
|
|
public static Float valueOf(String s) {
|
|
|
|
return new Float(s);
|
|
|
|
}
|
|
|
|
|
2007-07-29 23:32:23 +00:00
|
|
|
public boolean equals(Object o) {
|
|
|
|
return o instanceof Float && ((Float) o).value == value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int hashCode() {
|
|
|
|
return floatToRawIntBits(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
public String toString() {
|
|
|
|
return toString(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static String toString(float v) {
|
2007-10-02 15:23:49 +00:00
|
|
|
return Double.toString(v);
|
2007-07-29 23:32:23 +00:00
|
|
|
}
|
|
|
|
|
2007-07-21 17:50:26 +00:00
|
|
|
public byte byteValue() {
|
|
|
|
return (byte) value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public short shortValue() {
|
|
|
|
return (short) value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int intValue() {
|
|
|
|
return (int) value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public long longValue() {
|
|
|
|
return (long) value;
|
|
|
|
}
|
|
|
|
|
2007-07-20 03:18:25 +00:00
|
|
|
public float floatValue() {
|
|
|
|
return value;
|
|
|
|
}
|
2007-07-21 17:50:26 +00:00
|
|
|
|
|
|
|
public double doubleValue() {
|
|
|
|
return (double) value;
|
|
|
|
}
|
2007-07-29 23:32:23 +00:00
|
|
|
|
2008-02-28 15:35:16 +00:00
|
|
|
public boolean isInfinite() {
|
|
|
|
return isInfinite(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isNaN() {
|
|
|
|
return isNaN(value);
|
|
|
|
}
|
|
|
|
|
2007-09-12 01:13:05 +00:00
|
|
|
public static float parseFloat(String s) {
|
2008-02-28 15:35:16 +00:00
|
|
|
int[] numRead = new int[1];
|
|
|
|
float f = floatFromString(s, numRead);
|
|
|
|
if (numRead[0] == 1) {
|
|
|
|
return f;
|
|
|
|
} else {
|
|
|
|
throw new NumberFormatException(s);
|
|
|
|
}
|
2007-09-12 01:13:05 +00:00
|
|
|
}
|
2011-12-28 22:52:53 +00:00
|
|
|
|
|
|
|
public static int floatToIntBits(float value) {
|
|
|
|
int result = floatToRawIntBits(value);
|
|
|
|
|
|
|
|
// Check for NaN based on values of bit fields, maximum
|
|
|
|
// exponent and nonzero significand.
|
|
|
|
if (((result & EXP_BIT_MASK) == EXP_BIT_MASK) && (result & SIGNIF_BIT_MASK) != 0) {
|
|
|
|
result = 0x7fc00000;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
2007-09-12 01:13:05 +00:00
|
|
|
|
2007-08-18 17:15:03 +00:00
|
|
|
public static native int floatToRawIntBits(float value);
|
|
|
|
|
|
|
|
public static native float intBitsToFloat(int bits);
|
2008-02-28 15:35:16 +00:00
|
|
|
|
|
|
|
public static native boolean isInfinite(float value);
|
|
|
|
|
|
|
|
public static native boolean isNaN(float value);
|
|
|
|
|
|
|
|
public static native float floatFromString(String s, int[] numRead);
|
2007-07-20 03:18:25 +00:00
|
|
|
}
|