C语言实现分布式自增有序的唯一ID生成算法-snowflake算法

之前有人问我设计一个分布式的递增的唯一id生成。想了半天不知道,偶然一个同事说起snowflake算法,我百度了一下,很简单高效。

参考

https://github.com/twitter/snowflake

于是,我自己用c语言随便实现了一下,还没有达到工业级别,需要细化,但是基本能用了,上代码。

[cpp]  view plain   copy
  1. /* 
  2.     snowflake 
  3.      
  4.     ID 生成策略 
  5.     毫秒级时间41位+机器ID 10位+毫秒内序列12位。 
  6.     0 41 51 64 +-----------+------+------+ |time |pc |inc | +-----------+------+------+ 
  7.     前41bits是以微秒为单位的timestamp。 
  8.     接着10bits是事先配置好的机器ID。 
  9.     最后12bits是累加计数器。 
  10.     macheine id(10bits)标明最多只能有1024台机器同时产生ID,sequence number(12bits)也标明1台机器1ms中最多产生4096个ID, * 
  11.       注意点,因为使用到位移运算,所以需要64位操作系统,不然生成的ID会有可能不正确 
  12. */  
  13.   
  14. #include <stdio.h>  
  15. #include <pthread.h>  
  16. #include <unistd.h>  
  17. #include <stdlib.h>  
  18. #include <sched.h>  
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值