public class Uuid extends Object implements Serializable
Uuid
s 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 Externalizable
public 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 null
protected 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.