All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.virtdata.basicsmappers.from_long.to_uuid.ToUUID Maven / Gradle / Ivy

package io.virtdata.basicsmappers.from_long.to_uuid;

import io.virtdata.annotations.ThreadSafeMapper;
import io.virtdata.basicsmappers.from_long.to_long.Hash;

import java.util.UUID;
import java.util.function.LongFunction;

/**
 * This function creates a non-random UUID in the type 4 version (Random).
 * It always puts the same value in the MSB position of the UUID format.
 * The input value is put in the LSB position.
 * 
 * xxxxxxxx-xxxx-Mxxx-Nxxx-xxxxxxxxxxxx
 * mmmmmmmm-mmmm-Mmmm-Llll-llllllllllll
 *               4    3
 * 
* As shown above, the LSB position does not have the complication of having * a version identifier (position M) dividing the dynamic range of the data type. * For this reason, only the LSB side is used for this mapper, which allows * an effective range of Long.MAX_VALUE/8, given the loss of 3 digits of precision. * * This function is suitable for deterministic testing of scenarios which depend * on type 4 UUIDs, but without the mandated randomness that makes testing difficult. * Just be aware that the MSB will always contain value 0x0123456789ABCDEFL unless you * specify a different long value to pre-fill it with. */ @ThreadSafeMapper public class ToUUID implements LongFunction { private final long msbs; private Hash longHash = new Hash(); public ToUUID() { // Something memorable, but the correct version this.msbs = (0x0123456789ABCDEFL & 0xFFFFFFFFFFFF0FFFL) | 0x0000000000004000L; } public ToUUID(long msbs) { this.msbs = (msbs & 0xFFFFFFFFFFFF0FFFL) | 0x0000000000004000L;; } @Override public UUID apply(long value) { long lsbs = (value & 0x1FFFFFFFFFFFFFFFL) | 0x8000000000000000L; UUID uuid= new UUID(msbs,lsbs); return uuid; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy