C++雪花算法实现

Wesley13
• 阅读 787

看来一下雪花算法的实现方法,用 c++试着实现了一下,这里仅仅是实现了算法的流程,但是具体的细节,如并发、多线程访问等等没有具体考虑。
雪花算法的简单讲解参考

#include <sys/select.h>
#include <iostream>
#include <chrono>
#include <random>
#include <ctime>
using namespace std;

// 有序且全局唯一的 id

long long getTimeStamp() {
  return chrono::duration_cast<chrono::milliseconds>
  (chrono::system_clock::now().time_since_epoch()).count();
}

// sleep 1ms
void sleep_ms(unsigned int ms) {
  struct timeval time;
  time.tv_sec = ms / 1000;
  time.tv_usec = (ms / 1000) % 1000000;
  select(0, NULL, NULL, NULL, &time);
}

long long getNextMsTimeStamp() {
  sleep_ms(1);
  return getTimeStamp();
}

long long getMachineId() {
  default_random_engine e;
  e.seed(getTimeStamp());
  return e() % 1024;
}

long long lastTimeStamp = getTimeStamp();
long long sequence = 0;
long long sequenceMask = 0b111111111111;

long long getSnowflaksUid() {
  // 一位标识符,表示正负
  long long identifier = 0;
  // 41位时间戳,69年
  long long timeStamp = getTimeStamp();
  // 十位工作机器位 1024 节点
  long long machine = getMachineId();

  if (lastTimeStamp == timeStamp) {
    // 获取当前时间戳,如果等于上次时间戳(同一毫秒内),则序列号加一;否则序列号赋值为0,从0开始
    sequence = (sequence + 1) & (sequenceMask); 
    if (sequence == 0) {
      timeStamp = getNextMsTimeStamp();
    }
  } else {
    sequence = 0;
  }

  lastTimeStamp = timeStamp;
  return (timeStamp << 22) | (machine << 12) | sequence;
}

int main() {
  cout << getSnowflaksUid() << endl;
  return 0;
}

关注我的微信公众号
C++雪花算法实现

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
RRT算法在三维轨迹规划中的MATLAB仿真
RRT二维轨迹规划关于RRT二维轨迹规划以及matlab实现参考博客:RRT(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fwww.cnblogs.com%2F21207iHome%2Fp%2F7210543.html)RRT算法简单思路分析
Easter79 Easter79
3年前
springboot2结合mybatis拦截器实现主键自动生成
前言前阵子和朋友聊天,他说他们项目有个需求,要实现主键自动生成,不想每次新增的时候,都手动设置主键。于是我就问他,那你们数据库表设置主键自动递增不就得了。他的回答是他们项目目前的id都是采用雪花算法来生成,因此为了项目稳定性,不会切换id的生成方式。朋友问我有没有什么实现思路,他们公司的orm框架是mybatis,我就建议他说,不然让你老大把m
灯灯灯灯 灯灯灯灯
3年前
面试百度和美团,竟然问我多线程安全问题,正好撞在我知识点上
解决多线程安全问题无非两个方法synchronized和lock具体原理以及如何获取锁AQS算法本篇文章主要讲了lock的原理就是AQS算法,还有个姊妹篇讲解synchronized的实现原理也是阿里经常问的,一定要看后面的文章,先说结论:非公平锁tryAcquire的流程是:检查state字段,若为0,表示锁未被占用,那么尝试占用,若不为0,检查
Wesley13 Wesley13
3年前
Java集合,ConcurrentHashMap底层实现和原理(常用于并发编程)
概述ConcurrentHashMap常用于并发编程,这里就从源码上来分析一下ConcurrentHashMap数据结构和底层原理。在开始之前先介绍一个算法,这个算法和Concurrent的实现是分不开的。CAS算法:CAS是英文单词CompareAndSwap的缩写,翻译过来就是比较并替换。CAS机制当中使用
Stella981 Stella981
3年前
Spring Bean生命周期
1\.简介在【Spring核心流程梳理】我们介绍了Spring容器的refresh过程,但是我们并没有进入到SpringBean的创建等生命周期等内容。这里,就来梳理一下SpringBean的生命周期。我们还是关注流程,重点关注核心的入口,忽略具体实现的细节。目标也很简单:1.知道SpringBean相关的扩展点
Stella981 Stella981
3年前
Nginx的负载均衡
上篇blog讲述了加权轮询算法的原理、以及负载均衡模块中使用的数据结构,接着我们来看看加权轮询算法的具体实现。 指令的解析函数 如果upstream配置块中没有指定使用哪种负载均衡算法,那么默认使用加权轮询。也就是说使用加权轮询算法,并不需要特定的指令,因此也不需要实现指令的解析函数。而实际上,和其它负载均衡算法不同(比如ip\_ha
Wesley13 Wesley13
3年前
MPI n 体问题
▶《并行程序设计导论》第六章中讨论了n体问题,分别使用了MPI,Pthreads,OpenMP来进行实现,这里是MPI的代码,分为基本算法和简化算法(引力计算量为基本算法的一半,但是消息传递较为复杂)●基本算法1//mpi_nbody_basic.c,MPI基本算法2include<stdio.h
Wesley13 Wesley13
3年前
Java容器解析系列(17) LruCache详解
在之前讲LinkedHashMap(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fwww.cnblogs.com%2Fjamesvoid%2Fp%2F9919075.html)的时候,我们说起可以用来实现LRU(leastrecentused)算法,接下来我看一下其中的一个
Stella981 Stella981
3年前
Python遗传算法工具箱DEAP框架分析
  本文主要介绍python遗传算法工具箱DEAP的实现。先介绍deap的如何使用,再深入介绍deap的框架实现,以及遗传算法的各种实现算法。  代码可以参考https://github.com/sumatrae/deap  下面是使用deap求解TSP的实现:1importarray2importrandom
拆解雪花算法生成规则 | 京东物流技术团队
雪花算法(Snowflake)是一种生成分布式全局唯一ID的算法,生成的ID称为SnowflakeIDs或snowflakes。这种算法由Twitter创建,并用于推文的ID。目前仓储平台生成ID是用的雪花算法修改后的版本。