public class Uuid extends Object implements Serializable
Uuids are equal if
they have the same 128-bit value. Uuid instances can be created using the static
methods of the UuidFactory class.
The design of this class is intended to support the use of universally unique identifiers that
Uuid as a
capability. Note that not all defined Uuid values imply a generation algorithm that
supports this goal.
The most significant 64 bits of the value can be decomposed into unsigned integer fields according to the following bit masks:
0xFFFFFFFF00000000 time_low 0x00000000FFFF0000 time_mid 0x000000000000F000 version 0x0000000000000FFF time_hi
The least significant 64 bits of the value can be decomposed into unsigned integer fields according to the following bit masks:
0xC000000000000000 variant 0x3FFF000000000000 clock_seq 0x0000FFFFFFFFFFFF node
This specification defines the meaning (and implies aspects of the generation algorithm) of
Uuid values if the variant field is 0x2 and the version
field is either 0x1 or 0x4.
If the version field is 0x1, then
time_low, time_mid, and time_hi fields are the
least, middle, and most significant bits (respectively) of a 60-bit timestamp of 100-nanosecond
intervals since midnight, October 15, 1582 UTC,
clock_seq field is a 14-bit number chosen to help avoid duplicate
Uuid values in the event of a changed node address or a backward system clock
adjustment (such as a random number when in doubt, or the previously used number incremented by
one if just a backward clock adjustment is detected), and
node field is an IEEE 802 address (a 48-bit value).
As an alternative to an IEEE 802 address (such as if one is not available to the generation
algorithm), the node field may also be a 48-bit number for which the most
significant bit is set to 1 and the remaining bits were produced from a
cryptographically strong random sequence.
If the version field is 0x4, then the time_low,
time_mid, time_hi, clock_seq, and node fields
are values that were produced from a cryptographically strong random sequence.
Only Uuid values with a version field of 0x4 are
considered computationally difficult to guess. A Uuid value with a
version field of 0x1 should not be treated as a capability.
A subclass of Uuid must not implement Externalizable; this restriction is
enforced by this class's constructor and readObject methods.
| Constructor and Description |
|---|
Uuid(long bits0,
long bits1)
Creates a new
Uuid with the specified 128-bit value. |
| Modifier and Type | Method and Description |
|---|---|
boolean |
equals(Object obj)
Compares the specified object with this
Uuid for equality. |
protected void |
finalize()
Delegates to the superclass's
finalize method. |
long |
getLeastSignificantBits()
Returns the least significant 64 bits of this
Uuid's 128-bit value. |
long |
getMostSignificantBits()
Returns the most significant 64 bits of this
Uuid's 128-bit value. |
int |
hashCode()
Returns the hash code value for this
Uuid. |
protected Object |
readResolve()
Returns this object.
|
String |
toString()
Returns a string representation of this
Uuid. |
void |
write(OutputStream out)
Marshals a binary representation of this
Uuid to an OutputStream. |
protected Object |
writeReplace()
Returns this object.
|
public Uuid(long bits0,
long bits1)
Uuid with the specified 128-bit value.bits0 - the most significant 64 bits of the 128-bit valuebits1 - the least significant 64 bits of the 128-bit valueSecurityException - if the class of this object implements Externalizablepublic final long getMostSignificantBits()
Uuid's 128-bit value.public final long getLeastSignificantBits()
Uuid's 128-bit value.public final int hashCode()
Uuid.public final boolean equals(Object obj)
Uuid for equality.
This method returns true if and only if the specified object is a
Uuid instance with the same 128-bit value as this one.public final String toString()
Uuid.
The string representation is 36 characters long, with five fields of zero-filled, lowercase hexadecimal numbers separated by hyphens. The fields of the string representation are derived from the components of the 128-bit value in the following order:
time_low (8 hexadecimal digits)
time_mid (4 hexadecimal digits)
version and time_hi treated as a single field (4 hexadecimal
digits)
variant and clock_seq treated as a single field (4 hexadecimal
digits)
node (12 hexadecimal digits)
As an example, a Uuid with the 128-bit value
0x0123456789ABCDEF0123456789ABCDEFwould have the following string representation:
01234567-89ab-cdef-0123-456789abcdef
public final void write(OutputStream out) throws IOException
Uuid to an OutputStream.
Specifically, this method writes the 128-bit value to the stream as 16 bytes in network (big-endian) byte order.
out - the OutputStream to write this Uuid toIOException - if an I/O exception occurs while performing this operationNullPointerException - if out is nullprotected final void finalize()
throws Throwable
finalize method. This method prevents
a subclass from declaring an overriding finalize method.protected final Object writeReplace()
writeReplace method with an alternate implementation.protected final Object readResolve()
readResolve method with an alternate implementation.Copyright © GigaSpaces.