Spec-Zone .ru
спецификации, руководства, описания, API
|
java.lang.Float
public final classFloat
extends Number { public static final floatMIN_VALUE
= 1.4e-45f; public static final floatMAX_VALUE
= 3.4028235e+38f; public static final floatNEGATIVE_INFINITY
= -1.0f/0.0f; public static final floatPOSITIVE_INFINITY
= 1.0f/0.0f; public static final floatNaN
= 0.0f/0.0f; publicFloat
(float value); publicFloat
(double value); publicFloat
(String s) throws NumberFormatException; public StringtoString
(); public booleanequals
(Object obj); public inthashCode
(); public intintValue
(); public longlongValue
(); public floatfloatValue
(); public doubledoubleValue
(); public static StringtoString
(float f); public static FloatvalueOf
(String s) throws NullPointerException, NumberFormatException; public booleanisNaN
(); public static booleanisNaN
(float v); public booleanisInfinite
(); public static booleanisInfinite
(float v); public static intfloatToIntBits
(float value); public static floatintBitsToFloat
(int bits); }
20.9.1 public static final float
MIN_VALUE
= 1.4e-45f;
Постоянная величина этого поля является самым маленьким положительным ненулевым значением типа float
. Это равно значению, возвращенному Float.intBitsToFloat(0x1)
.
20.9.2 public static final float
MAX_VALUE
= 3.4028235e+38f;
Постоянная величина этого поля является самым большим положительным конечным значением типа float
. Это равно значению, возвращенному Float.intBitsToFloat(0x7f7fffff)
.
20.9.3 public static final float
NEGATIVE_INFINITY
=
-1.0f/0.0f;
Постоянная величина этого поля является отрицательной бесконечностью типа float
. Это равно значению, возвращенному Float.intBitsToFloat(0xff800000)
.
20.9.4 public static final float
POSITIVE_INFINITY
=
1.0f/0.0f;
Постоянная величина этого поля является положительной бесконечностью типа float
. Это равно значению, возвращенному Float.intBitsToFloat(0x7f800000)
.
20.9.5 public static final float
NaN
= 0.0f/0.0f;
Постоянная величина этого поля является значением Не-числа типа float
. Это равно значению, возвращенному Float.intBitsToFloat(0x7fc00000)
.
20.9.6 public
Float
(float value)
Этот конструктор инициализирует недавно создаваемый Float
возразите так, чтобы это представило примитивное значение, которое является параметром.
20.9.7 public
Float
(double value)
Этот конструктор инициализирует недавно создаваемый Float
возразите так, чтобы это представило результат сужения (§5.1.3) параметр от типа double
вводить float
.
20.9.8 public
Float
(String s) throws NumberFormatException
Этот конструктор инициализирует недавно создаваемый Float
возразите так, чтобы это представило значение с плавающей точкой типа float
представленный строкой. Строка преобразовывается в a float
значение точно способом, используемым valueOf
метод (§20.9.17).
20.9.9 public String
toString
()
Примитив float
значение представляется этим Float
объект преобразовывается в строку точно как будто методом toString
из одного параметра (§20.9.16).
Переопределения toString
метод Object
(§20.1.2).
20.9.10 public boolean
equals
(Object obj)
Результат true
если и только если параметр не null
и a Float
объект, который представляет то же самое float
оцените как это Float
объект. С этой целью, два float
значения, как полагают, являются тем же самым если и только если метод floatToIntBits
(§20.9.22) возвращает то же самое int
оцените когда применено к каждого. Отметьте это даже при том, что ==
оператор возвращается false
если обоими операндами является НЭН, это equals
метод возвратится true
если это Float
возразите и параметр оба Float
объекты, которые представляют НЭН. С другой стороны, даже при том, что ==
оператор возвращается true
если один операнд является положительным нулем, и другой отрицательный нуль, это equals
метод возвратится false
если это Float
возразите и параметр представляют, обнуляет различного знака. Это определение позволяет хеш-таблицам работать должным образом.
Переопределения equals
метод Object
(§20.1.3).
20.9.11 public int
hashCode
()
Результатом является целочисленное разрядное представление, точно как произведено методом floatToIntBits
(§20.9.22), примитива float
значение представляется этим Float
объект.
Переопределения hashCode
метод Object
(§20.1.4).
20.9.12 public int
intValue
()
float
значение представляется этим Float
объект преобразовывается (§5.1.3), чтобы ввести int
и результат преобразования возвращается.
Переопределения intValue
метод Number
(§20.6.1).
20.9.13 public long
longValue
()
float
значение представляется этим Float
объект преобразовывается (§5.1.3), чтобы ввести long
и результат преобразования возвращается.
Переопределения longValue
метод Number
(§20.6.2).
20.9.14 public float
floatValue
()
float
значение представляется этим Float
объект возвращается.
Переопределения floatValue
метод Number
(§20.6.3).
20.9.15 public double
doubleValue
()
float
значение представляется этим Float
объект преобразовывается (§5.1.2), чтобы ввести double
и результат преобразования возвращается.
Переопределения doubleValue
метод Number
(§20.6.4).
20.9.16 public static String
toString
(float f)
Параметр преобразовывается в читаемый строковый формат следующим образом. Все символы и символы в строках, упомянутых ниже, являются символами ASCII.
"NaN"
.
'-'
('\u002d'
); если знак положителен, никакой символ знака не появляется в результате. Что касается величины м.: Infinity
"; таким образом положительная бесконечность приводит к результату "Infinity"
и отрицательная бесконечность приводит к результату "-Infinity"
.
"0.0"
; таким образом отрицательный нуль приводит к результату "-0.0"
и положительный нуль приводит к результату "0.0"
.
'.'
(\u002E
), сопровождаемый одной или более десятичными цифрами, представляющими дробную часть м.
'.'
(\u002E
), сопровождаемый десятичными цифрами, представляющими дробную часть a, сопровождаемого буквой 'E'
(\u0045
), сопровождаемый представлением n как десятичное целое число, как произведено методом Integer.toString
из одного параметра (§20.7.12). float
. Таким образом, предположите, что x является точным математическим значением, представленным десятичным представлением, произведенным этим методом для конечного ненулевого параметра f. Затем f должен быть float
оцените самый близкий x; или, если два float
значения одинаково близко к x, тогда f должен быть одним из них, и младший значащий бит мантиссы f должен быть 0
.
[Эта спецификация для метода toString
планируется для введения в версии 1.1 Java. В предыдущих версиях Java этот метод производит Inf
вместо Infinity
для бесконечных значений. Кроме того, это представляет конечные значения в той же самой форме как %g
формат printf
функция в языке программирования C, который может потерять точность, потому что это производит самое большее шесть цифр после десятичной точки.]
20.9.17 public static Float
valueOf
(String s)
throws NullPointerException, NumberFormatException
Строка s
интерпретируется как представление значения с плавающей точкой и a Float
объект, представляющий то значение, создается и возвращается.
Если s
null
, тогда a NullPointerException
бросается.
Продвижение и запаздывание пробела (§20.5.19) символы в s
игнорируются. Остальная часть s
должен составить FloatValue как описано лексическими правилами синтаксиса:
FloatValue:где Знак, Цифры, и ExponentPart как определяются в §3.10.2. Если у этого нет формы FloatValue, то a
SignoptDigits
.
DigitsoptExponentPartopt
Signopt.
DigitsExponentPartopt
NumberFormatException
бросается. Иначе, это расценивается как представление точного десятичного значения в обычном "компьютеризированном экспоненциальном представлении"; это точное десятичное значение тогда концептуально преобразовывается в "бесконечно точное" двоичное значение, которое тогда округляется, чтобы ввести float
по обычному правилу раунда-к-самому-близкому IEEE 754 арифметика с плавающей точкой. Наконец, новый объект класса Float
создается, чтобы представить это float
значение. Не отметьте это ни один F
ни f
разрешается появиться в s
как индикатор типа, как был бы разрешен в исходном коде Java (§3.10.1).
20.9.18 public boolean
isNaN
()
Результат true
если и только если значение представляется этим Float
объектом является НЭН.
20.9.19 public static boolean
isNaN
(float v)
Результат true
если и только если значением параметра является НЭН.
20.9.20 public boolean
isInfinite
()
Результат true
если и только если значение представляется этим Float
объект является положительной бесконечностью или отрицательной бесконечностью.
20.9.21 public static boolean
isInfinite
(float v)
Результат true
если и только если значение параметра является положительной бесконечностью или отрицательной бесконечностью.
20.9.22 public static int
floatToIntBits
(float value)
Результатом является представление параметра с плавающей точкой согласно IEEE 754 "единственный формат с плавающей точкой" разрядное расположение:
0x80000000
) представляет знак числа с плавающей точкой.
0x7f800000
) представьте экспоненту.
0x007fffff
) представьте мантиссу (иногда названный мантиссой) числа с плавающей точкой.
0x7f800000
.
0xff800000
.
0x7fc00000
. intBitsToFloat
метод (§20.9.23), произведет значение с плавающей точкой, равное параметру floatToIntBits
.20.9.23 public static float
intBitsToFloat
(int bits)
Параметром, как полагают, является представление значения с плавающей точкой согласно IEEE 754 "единственный формат с плавающей точкой" разрядное расположение. То значение с плавающей точкой возвращается как результат.
0x7f800000
, результатом будет положительная бесконечность.
0xff800000
, результатом будет отрицательная бесконечность.
0x7f800001
через 0x7fffffff
или в диапазоне 0xff800001
через 0xffffffff
, результатом будет НЭН. (Весь IEEE 754 значения НЭН, в действительности, смешивается языком Java в единственное значение по имени НЭН.)
int s = ((bits >> 31) == 0) ? 1 : -1; int e = ((bits >> 23) & 0xff); int m = (e == 0) ? (bits & 0x7fffff) << 1 : (bits & 0x7fffff) | 0x800000;Затем результат с плавающей точкой равняется значению математического выражения.
Содержание | Предыдущий | Следующий | Индекс
Спецификация языка Java (HTML, сгенерированный Блинчиком "сюзет" Pelouch 24 февраля 1998)
Авторское право © Sun Microsystems, Inc 1996 года. Все права защищены
Пожалуйста, отправьте любые комментарии или исправления к doug.kramer@sun.com