文章背景:雪花算法 id 生成长度问题。

Java位运算符
- 异或运算符(^)
<p>运算规则:两个数转为二进制,然后从高位开始比较,如果相同则为0,不相同则为1。</p> - 与运算符(&)
<p>运算规则:两个数都转为二进制,然后从高位开始比较,如果两个数都为1则为1,否则为0。</p> - 或运算符(|)
<p>运算规则:两个数都转为二进制,然后从高位开始比较,两个数只要有一个为1则为1,否则就为0。</p> - 非运算符(~)
<p>运算规则:如果位为0,结果是1,如果位为1,结果是0。</p>

Java位移运算符
- 左位移运算符(<<)
<p>运算规则:按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。</p> - 有符号右位移运算符(>>)
<p>运算规则:按二进制形式把所有的数字向右移动对应的位数,低位移出(舍弃);若符号位正,则在高位插入0;若符号位负。则在高位插入1。</p> - 无符号右移运算符(>>>)
<p>运算规则:忽略符号位,空位都以0补齐</p>

原码、反码、补码
- 原码<br>
+1的原码 0000 0001<br>
-1的原码 1000 0001<br> - 反码<br>
正数的反码是其本身<br>
负数的反码是在其原码的基础上, 符号位不变,其余各个位取反。 - 补码<br>
正数的补码就是其本身<br>
负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1。(即在反码的基础上+1)

Java int 转 byte
- java采用补码存储整数。int型为4字节32位,byte为1字节8位。<br>
所以byte[]数组中存储一个int类型肯定是4个1字节的byte组成,即byte\[4\]才可以存放一个int值

java中基本类型占用字节数
| type       | byte   |  bit   |
| -------- | -----: | :----: |
| long | 8 | 64 |
| int | 4 | 16 |
 
SnowFlake生成的id的长度主要受创始时间戳影响。
41位时间截不是存储当前时间的时间截,而是存储时间截的差值(当前时间截 - 开始时间截) 得到的值。这个差值越来越大,导致生成的id位数增加。


最新文章

  1. C# Windows service 开发笔录
  2. 【MySQL】游标的具体使用详解
  3. bootstrap ace treeview树表
  4. XueXX and Chessboard(dp)
  5. file_get_content和curl的性能比较
  6. hdu 1056
  7. vs UNICODE 零散的笔记
  8. D - Common Subsequence
  9. 经常使用的时间同步server地址
  10. Cocos2d-x 学习(1)—— 通过Cocos Studio创建第一个Demo
  11. 39.Linux应用调试-strace命令
  12. JSON Patch
  13. 强杀apt-get install进程导致错误的修复办法
  14. win10锁屏或睡眠一段时间后弹不出登录框
  15. Oracle 的ORION工具简单使用
  16. 避免代码merge后无法构建发布(GItlabCI + Jenkins)
  17. Apache Hadoop 3.0新版本介绍及未来发展方向
  18. Tars环境搭建之路
  19. FastReport.net 常用方法
  20. [Agc008F]Black Radius

热门文章

  1. golang测试
  2. Tomcat内存溢出解决方法
  3. maven nexus 私服搭建 Windows版
  4. Win 8\10系统安装软件报错
  5. js定时器关闭,js定时器停止,一次关闭所有正在运行的定时器,自定义函数clearIntervals()一次关闭所有正在运行的定时器
  6. Virtual DOM--react
  7. 函数式编程之moand的作用
  8. round.606.div2
  9. MongoDB shell 1 数据库方法
  10. 修改 oracle xe 默认中文字符集成为:SIMPLIFIED CHINESE_CHINA.ZHS16GBK