基于php雪花算法工具类Snowflake -来自chatGPT

news/2025/1/15 13:05:43/
<?phpclass Snowflake {// 定义Snowflake算法的各个参数private $workerIdBits = 5;private $datacenterIdBits = 5;private $sequenceBits = 12;private $workerIdShift;private $datacenterIdShift;private $timestampLeftShift;private $maxWorkerId;private $maxDatacenterId;private $sequenceMask;private $workerId;private $datacenterId;private $sequence = 0;private $lastTimestamp = -1;public function __construct($workerId, $datacenterId) {// 计算位偏移量$this->workerIdShift = $this->sequenceBits;$this->datacenterIdShift = $this->sequenceBits + $this->workerIdBits;$this->timestampLeftShift = $this->sequenceBits + $this->workerIdBits + $this->datacenterIdBits;// 计算最大ID$this->maxWorkerId = -1 ^ (-1 << $this->workerIdBits);$this->maxDatacenterId = -1 ^ (-1 << $this->datacenterIdBits);$this->sequenceMask = -1 ^ (-1 << $this->sequenceBits);// 初始化参数$this->workerId = $workerId;$this->datacenterId = $datacenterId;}// 生成下一个唯一IDpublic function generateId() {// 获取当前时间戳(毫秒级)$timestamp = floor(microtime(true) * 1000);// 如果当前时间小于上次生成ID的时间戳,则抛出异常if ($timestamp < $this->lastTimestamp) {throw new Exception("Invalid system clock!");}// 如果当前时间戳与上次时间戳相同,则自增序列号if ($timestamp == $this->lastTimestamp) {$this->sequence = ($this->sequence + 1) & $this->sequenceMask;// 如果序列号等于0,则需要进入下一毫秒重新生成IDif ($this->sequence == 0) {$timestamp = $this->waitNextMillis($this->lastTimestamp);}} else {$this->sequence = 0;}// 保存最后生成ID的时间戳$this->lastTimestamp = $timestamp;// 生成最终的唯一ID$uniqueId = (($timestamp << $this->timestampLeftShift) |($this->datacenterId << $this->datacenterIdShift) |($this->workerId << $this->workerIdShift) |$this->sequence);return $uniqueId;}// 阻塞到下一个毫秒,直到获得新的时间戳private function waitNextMillis($lastTimestamp) {$timestamp = floor(microtime(true) * 1000);while ($timestamp <= $lastTimestamp) {usleep(1000);$timestamp = floor(microtime(true) * 1000);}return $timestamp;}
}// 测试方法
$snowflake = new Snowflake(1, 1);
for ($i = 0; $i < 10; $i++) {$uniqueId = $snowflake->generateId();echo $uniqueId . "\n";
}?>

在上述代码中,我们创建了一个名为Snowflake的类,该类用于生成Snowflake算法的唯一ID。它具有以下主要属性和方法:

  • __construct($workerId, $datacenterId):初始化Snowflake算法的参数,包括工作节点ID(workerId)和数据中心ID(datacenterId)。
  • generateId():生成下一个唯一ID。
  • waitNextMillis($lastTimestamp):阻塞到下一个毫秒,直到获得新的时间戳。

在测试方法中,我们创建了一个Snowflake实例,并使用其generateId()方法生成了10个唯一ID,并打印出来。


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

相关文章

夏季必备的开放式耳机,轻巧挂耳音效出色,sanag塞那 Z65S Pro Max

蓝牙耳机如今已经非常流行了&#xff0c;今年又出现了很多异形的蓝牙耳机&#xff0c;像是夹耳式、分体式、挂耳式等&#xff0c;这类耳机大多还采用了骨传导、气传导等创新技术&#xff0c;主要目的无非是为了提升佩戴的稳定性、舒适性和安全性&#xff0c;尤其是到了炎热的夏…

css实现卡片的左上角有一个三角形的遮盖效果

需求: 卡片的左上角有一个绿色的三角形标签,用来区分状态 实现: .vCard{position: relative;overflow: hidden; } .vCard::before {content: "";position: absolute;top: 0;left: 0;width: 0;height: 0;border-bottom: 20px solid transparent;border-left: 20px …

优化|当机器学习上运筹学:PyEPO与端对端预测后优化

分享者&#xff1a;唐博 编者按&#xff1a;​ 这篇文章我想要写已经很久了&#xff0c;毕竟“端对端预测后优化”&#xff08;End-to-End Predict-then-Optimize&#xff09;正是我读博期间的主要研究方向&#xff0c;但我又一直迟迟没能下笔。想说自己杂事缠身&#xff08;实…

Python二维数组的坑:vis = [[0]*m] * n

先来看&#xff0c;vis [[0]*m] * n&#xff0c; vis2 [[0]*m for _ in range(n)]有什么区别&#xff1f; 这两行代码都是用来创建二维列表&#xff08;或矩阵&#xff09;&#xff0c;但它们之间有一个关键的区别在于列表的复制方式。 vis [[0]*m] * n&#xff1a; 这种方…

【C++】类的隐式转换和explicit抑制类的隐式转换

2023年8月5日&#xff0c;周六下午 今天在网上找了很久都没找到有精确定义了类的隐式转换条件的资料&#xff0c;最后是在权威书籍《C Primer&#xff08;第5版&#xff09;》里面找到的。 说真的&#xff0c;虽然我认为《C Primer&#xff08;第5版&#xff09;》不适合作为…

开放式蓝牙耳机哪个品牌好用?盘点几款很不错的开放式耳机

​相比传统入耳式耳机&#xff0c;开放式耳机因其不入耳不伤耳的开放设计&#xff0c;不仅带来了舒适的佩戴体验&#xff0c;还创造了一种与周围环境互动的全新方式&#xff0c;户外运动过程时也无需担心发生事故&#xff0c;安全性更高。我整理了几款比较好用的开放式耳机给大…

re学习(28)攻防世界 parallel-comparator-200(线程函数)

下载出来是个C语言编辑文件&#xff0c;添加注释如下所示&#xff1a; #include <stdlib.h> #include <stdio.h> #include <pthread.h> //linux的线程库&#xff0c;所以要在linux中才可运行 #define FLAG_LEN 20void * checking(void *arg) { //这道题…

【Python从入门到进阶】31、使用JSONPath解析淘票票网站地区接口数据

接上篇《30、JSONPath的介绍和使用》 上一篇我们介绍了JSONPath的基础和具体使用&#xff0c;本篇我们来具体使用JSONPath&#xff0c;来解析淘票票网站的地区接口数据。 一、引言 1、JsonPath的作用和用途&#xff1f; JsonPath是一种用于在JSON数据中进行查询和提取的表达…