|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object java.lang.Number weblogic.wtc.jatmi.Decimal
public class Decimal
This class provides a Java implementation of the Tuxedo packed decimal
type. Packed decimals appear only in Tuxedo View buffers. The class
methods provide convenience routines to create packed decimals from
Strings and numbers and to convert a packed decimal object
to a String or number. A Decimal
encodes a number as
an array of bytes in base-100 and a signed exponent (-64 to +63).
The byte array is of fixed size with the implied decimal point to the
left of the first byte. The exponent represents powers of 100. A special
exponent value DECPOSNULL
indicates a Decimal
with null (undefined) value.
Field Summary | |
---|---|
static int |
DECPOSNULL
Exponent value indicating a null Decimal , i.e., a Decimal
with undefined value. |
static int |
DECSIZE
Size of the array of bytes representing the digits of the Decimal . |
Constructor Summary | |
---|---|
Decimal()
Constructs a newly allocated Decimal object with null value. |
|
Decimal(byte bval)
Constructs a newly allocated Decimal object from a
byte value. |
|
Decimal(double value)
Constructs a newly allocated Decimal object from a double value. |
|
Decimal(float value)
Constructs a newly allocated Decimal object from a float value. |
|
Decimal(int ival)
Constructs a newly allocated Decimal object from an
int value. |
|
Decimal(int sign,
int exponent,
int numDigits,
byte[] digits)
Constructs a newly allocated Decimal object using the values
specified by its parameters. |
|
Decimal(long lval)
Constructs a newly allocated Decimal object from a
long value. |
|
Decimal(short sval)
Constructs a newly allocated Decimal object from a
short value. |
|
Decimal(java.lang.String str)
Constructs a newly allocated Decimal object from a String value. |
Method Summary | |
---|---|
java.math.BigDecimal |
bigDecimalValue()
Converts the Decimal to a BigDecimal value. |
byte |
byteValue()
Converts the Decimal to a byte value. |
int |
compareTo(Decimal other)
Compares two Decimal objects numerically. |
int |
compareTo(java.lang.Object other)
Compares this Decimal object to another object. |
byte[] |
digits()
Returns the actual decimal digits. |
double |
doubleValue()
Converts the Decimal to a double value. |
boolean |
equals(java.lang.Object obj)
Compares this object to another object. |
int |
exponent()
Returns the exponent of the Decimal value. |
float |
floatValue()
Converts the Decimal to a float value. |
int |
intValue()
Converts the Decimal to an int value. |
long |
longValue()
Converts the Decimal to a long value. |
Decimal |
negate()
Creates a newly allocated Decimal whose value is (-this ). |
int |
numDigits()
Returns the number of significant digits in the Decimal value. |
short |
shortValue()
Converts the Decimal to a short value. |
int |
sign()
Returns the sign of the Decimal value. |
java.lang.String |
toString()
Converts the Decimal to a String . |
static java.lang.String |
toString(Decimal dec)
Converts the input Decimal to a String . |
static Decimal |
valueOf(java.lang.String s)
Constructs a newly allocated Decimal object from a String value. |
Methods inherited from class java.lang.Object |
---|
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
public static final int DECSIZE
Decimal
.
public static final int DECPOSNULL
Decimal
, i.e., a Decimal
with undefined value. Null Decimals cannot be compared numerically
with other Decimals.
Constructor Detail |
---|
public Decimal()
Decimal
object with null value.
The sign of the object is set to DECPOSNULL
.
Decimal.DECPOSNULL
public Decimal(int sign, int exponent, int numDigits, byte[] digits)
Decimal
object using the values
specified by its parameters.
sign
- the sign to set; 1 indicates a positive value,
0 a negative value and DECPOSNULL
a null value.exponent
- the exponent to set. It must be
between -64 and +63.numDigits
- the number of significant digits in the digits
array. This value must be less than or equal to DECSIZE
.digits
- an array of bytes representing the actual
digits of the decimal value. The bytes must be base-100
digits (0-99). Only the first numDigits bytes are used.
java.lang.NumberFormatException
- if any of the input parameters do not
obey the described constraintsDecimal.DECPOSNULL
,
Decimal.DECSIZE
public Decimal(double value) throws java.lang.NumberFormatException
Decimal
object from a double
value.
value
- the double
value to convert.
java.lang.NumberFormatException
- if the value would overflow or
underflow when converted to Decimal
or if the value
represents a NaN or infinity.public Decimal(float value) throws java.lang.NumberFormatException
Decimal
object from a float
value.
value
- the float
value to convert.
java.lang.NumberFormatException
- if the value represents a NaN or infinity.public Decimal(java.lang.String str) throws java.lang.NumberFormatException
Decimal
object from a String
value. The String
is converted to a Decimal
value as if by the valueOf
method.
str
- the String value to convert.
java.lang.NumberFormatException
- if the value is in the wrong format or
would overflow or underflow when converted to Decimal.Decimal.valueOf(String)
public Decimal(long lval)
Decimal
object from a
long
value.
lval
- the long
value to convert. If lval
represents the smallest long
value (Long.MIN_VALUE
),
a Decimal
with null value is created.public Decimal(int ival)
Decimal
object from an
int
value.
ival
- the int
value to convert. If ival
represents the smallest int
value (Integer.MIN_VALUE
),
a Decimal
with null value is created.public Decimal(short sval)
Decimal
object from a
short
value.
sval
- the short
value to convert. If sval
represents the smallest short
value (Short.MIN_VALUE
),
a Decimal
with null value is created.public Decimal(byte bval)
Decimal
object from a
byte
value.
bval
- the byte
value to convert. If bval
represents the smallest byte
value (Byte.MIN_VALUE
),
a Decimal
with null value is created.Method Detail |
---|
public int exponent()
Decimal
value. The exponent
represents powers of 100.
public int sign()
Decimal
value.
DECPOSNULL
a null value.Decimal.DECPOSNULL
public int numDigits()
Decimal
value.
Decimal
value.public byte[] digits()
public Decimal negate()
Decimal
whose value is (-this
).
Decimal
whose value is (-this
). If the original Decimal
has a null value, that is, its sign is DECPOSNULL
, a new null Decimal
is returned.Decimal.DECPOSNULL
public java.math.BigDecimal bigDecimalValue()
Decimal
to a BigDecimal
value.
BigDecimal
value representing the Decimal
. If
the Decimal
has a null value, a new BigDecimal(Double.MIN_VALUE)
is returned.public double doubleValue()
Decimal
to a double
value.
doubleValue
in class java.lang.Number
double
value representing the Decimal
. If
the Decimal
has a null value, Double.MIN_VALUE
is returned.public float floatValue() throws java.lang.NumberFormatException
Decimal
to a float
value.
floatValue
in class java.lang.Number
float
value representing the Decimal
. If
the Decimal
has a null value, Float.MIN_VALUE
is returned.
java.lang.NumberFormatException
- if the Decimal
value would cause overflow
when converted to a float
.public long longValue() throws java.lang.NumberFormatException
Decimal
to a long
value.
longValue
in class java.lang.Number
long
value representing the Decimal
. If
the Decimal
has a null value, Long.MIN_VALUE
is returned.
java.lang.NumberFormatException
- if the Decimal
value cannot be
represented as a long
.public int intValue() throws java.lang.NumberFormatException
Decimal
to an int
value.
intValue
in class java.lang.Number
int
value representing the Decimal
. If
the Decimal
has a null value, Integer.MIN_VALUE
is returned.
java.lang.NumberFormatException
- if the Decimal
value cannot be
represented as an int
.public short shortValue() throws java.lang.NumberFormatException
Decimal
to a short
value.
shortValue
in class java.lang.Number
short
value representing the Decimal
. If
the Decimal
has a null value, Short.MIN_VALUE
is returned.
java.lang.NumberFormatException
- if the Decimal
value cannot be
represented as a short
.public byte byteValue() throws java.lang.NumberFormatException
Decimal
to a byte
value.
byteValue
in class java.lang.Number
byte
value representing the Decimal
. If
the Decimal
has a null value, Byte.MIN_VALUE
is returned.
java.lang.NumberFormatException
- if the Decimal
value cannot be
represented as a byte
.public java.lang.String toString() throws java.lang.NumberFormatException
Decimal
to a String
. The String
is
in the format that the Java Double.toString
method would
generate for an equivalent double
value.
toString
in class java.lang.Object
String
value representing the Decimal
.
java.lang.NumberFormatException
- if the Decimal
value cannot be
represented as a double
.public static java.lang.String toString(Decimal dec) throws java.lang.NumberFormatException
Decimal
to a String
. The String
is
in the format that the Java Double.toString
method would
generate for an equivalent double
value.
dec
- the Decimal
object to convert.
String
value representing the Decimal
.
java.lang.NumberFormatException
- if the Decimal
value cannot be
represented as a double
.public static Decimal valueOf(java.lang.String s) throws java.lang.NumberFormatException
Decimal
object from a String
value. The String
is converted to a Decimal
value. The String
must be in the format accepted
by the Java Double.parseDouble
method.
str
- the String value to convert.
java.lang.NumberFormatException
- if the value is in the wrong format or
would overflow or underflow when converted to Decimal
.public int compareTo(java.lang.Object other) throws java.lang.NumberFormatException
Decimal
object to another object. If the
other object is a Decimal
, this function behaves like
compareTo(Decimal)
. Otherwise, it throws a ClassCastException
.
compareTo
in interface java.lang.Comparable
obj
- the other object to compare
java.lang.ClassCastException
- if obj is not a Decimal
java.lang.NumberFormatException
- if either of the objects has a null value,
that is, if their exponent is equal to DECPOSNULL
.Decimal.DECPOSNULL
public int compareTo(Decimal other) throws java.lang.NumberFormatException
Decimal
objects numerically. Neither
object can have a null value.
other
- a Decimal
that is compared against this
object.
java.lang.NumberFormatException
- if either of the objects has a null value,
that is, if their exponent is equal to DECPOSNULL
.Decimal.DECPOSNULL
public boolean equals(java.lang.Object obj)
Decimal
object with the same value as the current object. The values are
equal if the objects have identical bit patterns. Note that null
valued Decimals may be compared in this operation
(unlike compareTo(Decimal)
).
equals
in class java.lang.Object
obj
- the other object to compare
Decimal
with the same value as the current object.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |