②snowflake(雪花ID)

news/2024/11/7 12:31:19/

1.雪花ID概念

        雪花算法(Snowflake)是一种用于生成唯一标识符(ID)的分布式算法。它可以生成趋势递增且具有一定时间顺序的64位整数,适用于分布式系统中的唯一ID生成需求。

2.雪花ID结构

 0 |  41位时间戳   |  10位工作机器ID  |  12位序列号

3.雪花ID的特点

        传统自增id容易造成id重复冲突,而UUID是无序的会导致数据散乱,雪花ID就同时就有两者优点,唯一且有序递增

4.雪花ID的使用

4.1 雪花ID工具类

package com.woniuxy.property1002.util;
public class SnowflakeIdWorker {/*** 开始时间:2020-01-01 00:00:00*/private final long beginTs = 1577808000000L;private final long workerIdBits = 10;/*** 2^10 - 1 = 1023*/private final long maxWorkerId = -1L ^ (-1L << workerIdBits);private final long sequenceBits = 12;/*** 2^12 - 1 = 4095*/private final long maxSequence = -1L ^ (-1L << sequenceBits);/*** 时间戳左移22位*/private final long timestampLeftOffset = workerIdBits + sequenceBits;/*** 业务ID左移12位*/private final long workerIdLeftOffset = sequenceBits;/*** 合并了机器ID和数据标示ID,统称业务ID,10位*/private long workerId;/*** 毫秒内序列,12位,2^12 = 4096个数字*/private long sequence = 0L;/*** 上一次生成的ID的时间戳,同一个worker中*/private long lastTimestamp = -1L;/**** 雪花算法工具类的构造方法,需要传入实例id和集群id,在构造函数内首先判断是否超过最大的实例id并且实例id是否小于0,* 同样的去判断数据中心id,如果不符合要求,则抛出参数异常*/private SnowflakeIdWorker(long workerId) {if (workerId > maxWorkerId || workerId < 0) {throw new IllegalArgumentException(String.format("WorkerId必须大于或等于0且小于或等于%d", maxWorkerId));}this.workerId = workerId;}public synchronized long nextId() {long ts = System.currentTimeMillis();if (ts < lastTimestamp) {throw new RuntimeException(String.format("系统时钟回退了%d毫秒", (lastTimestamp - ts)));}// 同一时间内,则计算序列号if (ts == lastTimestamp) {// 序列号溢出if (++sequence > maxSequence) {ts = tilNextMillis(lastTimestamp);sequence = 0L;}} else {// 时间戳改变,重置序列号sequence = 0L;}lastTimestamp = ts;// 左移后,低位补0,进行按位或运算相当于二进制拼接// 本来高位还有个0<<63,0与任何数字按位或都是本身,所以写不写效果一样return (ts - beginTs) << timestampLeftOffset | workerId << workerIdLeftOffset | sequence;}/*** 阻塞到下一个毫秒*/private long tilNextMillis(long lastTimestamp) {long ts = System.currentTimeMillis();while (ts <= lastTimestamp) {ts = System.currentTimeMillis();}return ts;}//单例模式private static final SnowflakeIdWorker instance = new SnowflakeIdWorker(1);public static long newId(){return instance.nextId();}
}

4.2 调用它获取一个雪花ID

import com.woniuxy.property1002.util.SnowflakeIdWorker;@Override
public boolean chargeTenement(Order order) {//生成订单编号long orderno = SnowflakeIdWorker.newId();order.setOrderno(orderno+"");return moneyMapper.chargeTenement(order);
}

http://www.ppmy.cn/news/674049.html

相关文章

C语言 — 宏命令的使用

宏的命名规则建议 规则1&#xff1a;对于数值或者字符串等常量的定义&#xff0c;建议采用全大写的英文字母&#xff0c;单词之间加下划线‘_’的方式命名&#xff08;枚举常量同样建议使用此方式定义&#xff09;。 示例&#xff1a; #define PI_ROUNDED 3.14 获取结构体成…

C 语言中宏的正常用法

前言 本文介绍一些 C/C 中宏的正常用法。 以及一些你绝对不会想让你家孩子知道的令人惊叹的技术。 1 相关知识 宏是在编译之前由预处理器处理的替换规则, 仅进行字符串替换, 并没有值的感念. 宏有两种风格, 一种和对象类似: #define identifier replacement-list这里 ident…

C语言 宏的一些特殊用法

目录 一、undef 二、ifdef 三、ifndef 四、#if #elif #else 五、宏的特殊用法 5.1 输出不同类型的数据 5.2 offsetof 一、undef 用于移除宏定义&#xff1a; #include<stdio.h> #define MAX 100 int main() {printf("%d",MAX);#ifdef MAX#undef MAX#endi…

C语言宏使用的技巧

1. 简单的define定义 #define MAXTIME 1000 一个简单的MAXTIME就定义好了&#xff0c;它代表1000&#xff0c;如果在程序里面写 if(i<MAXTIME){.........} 编译器在处理这个代码之前会对MAXTIME进行处理替换为1000。 这样的定义看起来类似于普通的常量定义CONST&#x…

c语言宏代码大全,C语言宏

本篇文章帮大家学习c语言宏&#xff0c;包含了C语言宏使用方法、操作技巧、实例演示和注意事项&#xff0c;有一定的学习价值&#xff0c;大家可以用来参考。 宏是一种可由宏的值代替的代码段。 宏由#define指令定义。 有两种类型的宏&#xff1a; 类似对象的宏 类似函数的宏 类…

C++宏编程技巧

下面的代码并非按照规范格式来写&#xff0c;仅作示范用途。 常用符号 ## 连接符&#xff0c;可将多个标识符拼接起来&#xff0c;组成一个完整的标识符。 //定义宏&#xff0c;用来打印整型变量 #define PRINT(x) printf("%d\n", a##x)int a1 1; int a2 2;PRI…

获取并设置鼠标位置 C语言

转自&#xff1a;YALI_xunzhen 编译环境&#xff1a;DEV C 4.9.9.2(及以上) 所在函数库&#xff1a;windows.h 格式&#xff1a; 读取鼠标坐标 GetCursorPos(一个POINT变量地址) 设定鼠标坐标 SetCursorPos(坐标x值,坐标y值) PS:将鼠标移到(x,y) 下面是例子&#xff1a;移…

C语言中宏(macro)的特殊用法

SimpleScalar的源代码中对macro的运用可以说是炉火纯青&#xff0c;丰富的macro使得代码简介&#xff0c;逻辑清晰&#xff0c;但是也给我这些初学者们阅读代码造成了障碍&#xff0c;下面将几篇找到的相关资料贴出来&#xff0c;希望能对大家有用 C语言中的宏(Macro)是最令人…