当前位置 : 主页 > 编程语言 > java >

java 生成短id

来源:互联网 收集:自由互联 发布时间:2023-09-06
Java生成短ID 简介 在开发Java应用程序时,经常会遇到需要生成唯一标识符的情况。通常,我们会使用UUID(Universally Unique Identifier)来生成唯一标识符。然而,UUID生成的标识符太长了,不

Java生成短ID

简介

在开发Java应用程序时,经常会遇到需要生成唯一标识符的情况。通常,我们会使用UUID(Universally Unique Identifier)来生成唯一标识符。然而,UUID生成的标识符太长了,不适合在一些特定场景中使用,比如URL缩短、短信验证码等。为了解决这个问题,我们可以使用一些算法来生成短ID。

本文将介绍一个常用的算法——雪花算法(Snowflake Algorithm),它可以生成一个长度较短的唯一标识符。

雪花算法

雪花算法是Twitter开源的一个算法,用于生成全局唯一的ID。它的原理非常简单,可以分为以下几个部分:

  • 时间戳(41位):记录生成ID的时间戳,精确到毫秒级别。
  • 机器ID(10位):记录机器的唯一标识,可以手动指定或从机器的网卡中获取。
  • 序列号(12位):记录每个时间戳下生成的序列号,从0开始递增。

由于每个部分的位数是固定的,所以我们可以根据时间戳、机器ID和序列号生成一个64位的ID。由于时间戳占据了大部分的位数,所以生成的ID是趋势递增的,保证了生成的ID的有序性。

下面是一个使用Java实现雪花算法的示例代码:

public class SnowflakeIdGenerator {
    private static final long EPOCH = 1609459200000L;  // 2021-01-01 00:00:00
    private static final long MACHINE_ID_BITS = 10L;
    private static final long SEQUENCE_BITS = 12L;

    private static final long MAX_MACHINE_ID = (1L << MACHINE_ID_BITS) - 1L;
    private static final long MAX_SEQUENCE = (1L << SEQUENCE_BITS) - 1L;

    private long machineId;
    private long sequence = 0L;
    private long lastTimestamp = -1L;

    public SnowflakeIdGenerator(long machineId) {
        if (machineId < 0 || machineId > MAX_MACHINE_ID) {
            throw new IllegalArgumentException("Invalid machine ID");
        }
        this.machineId = machineId;
    }

    public synchronized long generateId() {
        long timestamp = System.currentTimeMillis();

        if (timestamp < lastTimestamp) {
            throw new RuntimeException("Clock moved backwards");
        }

        if (timestamp == lastTimestamp) {
            sequence = (sequence + 1) & MAX_SEQUENCE;
            if (sequence == 0) {
                timestamp = tilNextMillis(lastTimestamp);
            }
        } else {
            sequence = 0L;
        }

        lastTimestamp = timestamp;

        return ((timestamp - EPOCH) << (MACHINE_ID_BITS + SEQUENCE_BITS))
                | (machineId << SEQUENCE_BITS)
                | sequence;
    }

    private long tilNextMillis(long lastTimestamp) {
        long timestamp = System.currentTimeMillis();
        while (timestamp <= lastTimestamp) {
            timestamp = System.currentTimeMillis();
        }
        return timestamp;
    }
}

状态图

下面是雪花算法的状态图,使用mermaid语法绘制:

stateDiagram-v2
  [*] --> Idle
  Idle --> GeneratingId : generateId()
  GeneratingId --> Idle : ID generated

旅行图

下面是雪花算法的旅行图,使用mermaid语法绘制:

journey
  title Snowflake Algorithm Journey
  section Initialize
    [*] --> CheckMachineId : Initialize
    CheckMachineId --> [*] : Invalid machine ID
    CheckMachineId --> SetMachineId : Valid machine ID

  section Generate ID
    SetMachineId --> Idle : Start
    Idle --> GenerateId : generateId() called
    GenerateId --> Idle : ID generated

  section Handle Clock Backwards
    GenerateId --> ClockBackwards : Clock moved backwards
    ClockBackwards --> GenerateId : Retry

  section End
    GenerateId --> [*] : Stop

示例

下面是一个使用雪花算法生成短ID的示例:

public class ShortIdGeneratorExample {
    public static void main(String[] args) {
        SnowflakeIdGenerator idGenerator = new SnowflakeIdGenerator(1L);
        long id = idGenerator.generateId();
        String shortId = toShortId(id);
        System.out.println("Generated ID: " +
上一篇:java 命令行执行 main方法
下一篇:没有了
网友评论