java 生成objectid_算法~位运算ObjectId生成时的秒用

article/2025/10/3 9:28:20

位运算控制数字范围

通过位运算,可以对一个数进行限制,保证这个数在2n-1(3,7,15,31,63,127,255...)范围内,当大于指定的数时,会取这个0到2n-1里的某个数,不会让它溢出。

之前我写过的位运算的文章

本文在ObjectId里的应用

ObjectId最早在mongodb的分布式环境出现,用来生成主键,因为mongodb是一个集群的,分布式的,所以要求它的主键的要求更高;它主要使用一个12个字节进行存储,而我们知道每1个字节对应8位二进制数,而每4二进制数对应1个16进制数,所以12个字节用16进制表示,就是24个16进制字符组成。

03d8a5ccfb9508da844dcbdf1bed9d8c.png

位运算与实现范围限制

在使用&与运算时,我们知道它对2^-1有一个定理,16进制就是f,ff,fff,ffff,fffff....这些,它对应的二进制是由N个1组成的,它与其它数字进行与时就有一些特性(全1为1,有0则0),通过这个特性,我们可以限定一个数字范围。

@Test

public void bitOperator() {

log.info("10 & 7={}", 10 & 7);

log.info("3 & 7={}", 3 & 7);

log.info("10 & 255={}", 10 & 255);

log.info("300 & 255={}", 300 & 255); //255的16进制为ff,后面数字为2^n-1

}

结果

7477dc9c8771c10d16df3758021479c3.png

从图中可以看出,10 & 7中,10大于后面的7,由于使用了&运算,保证了结果在0~7之间;而3 & 7,由于3小于7,所以结果就是3本身。

二进制看个究竟

10对应的二进制1010

7 对应的二进制111

现在进行与运算

1010

&

0111

结果

0010

对应10进行是2,由于7是111组成,而10是1010,当位数不同时,需要为111补0,它就变成了0111,这时,高位由于是0,所以不论你的数有多大,结果都是0,最后也就是0到7之间的某个数了,至于是哪个数,这和你的原数有关,原数高位都是0,低位数字不变。

或运算实现从某个数开始计数

对于或运算,也有它的使用场景,我们以二进制说明,比如0x1000这个数(十进制是4096),其它数与它进行或运算,得到的结果将是从4096开始的数字,如果1 | 4096,结果将是4097,以此类推,不过有一点要注意,你的数字在4096范围内,它产生与4096作或运算,产生新的数字是不会重复的;但如果你的数字大于4096,比如4097|4096,它的结果将还是4097,这点需要注意。

如果我们确定了数字范围,可以利用这个性质,在一个较大的数字基础上,去产生新的数字。

begin = Long.parseLong("1000", 16);

for (int i = 0; i < 10; i++) {

log.info("{} | {} = {}", i, begin, i | begin);//超过begin之后,数字会有重复

}

结果

c8582b7b2e1ca1a1475ff0f472df4efd.png


http://chatgpt.dhexx.cn/article/C7oNWtIQ.shtml

相关文章

mongodb objectid java_我可以确定字符串是否是MongoDB ObjectID吗?

回答(10) 2 years ago 我发现mongoose ObjectId验证器用于验证有效的objectIds&#xff0c;但我发现了一些无效ID被认为有效的情况 . (例如&#xff1a;任何12个字符长的字符串) var ObjectId require(mongoose).Types.ObjectId; ObjectId.isValid(microsoft123); //true Obje…

MongoDB 认识ObjectId

官方文档&#xff1a;https://docs.mongodb.com/manual/reference/method/ObjectId/ 现在我们有一个集合如下 db.class0.insertMany([{"name": "一年级一班","headmaster": "王老师"},{"name": "一年级二班",&q…

mysql objectid_【Mongodb】_id和ObjectId详解!

2.6.6 _id和ObjectId MongoDB 中存储的文档必须有一个"_id" 键。这个键的值可以是任何类型的&#xff0c;默认是个ObjectId 对象。在一个集合里面&#xff0c;每个文档都有唯一的"_id" 值&#xff0c;来确保集合里面每个文档都能被唯一标识。如果有两个集合…

Mongodb ObjectId格式

ObjectId是一个24位的字符串&#xff0c;实际是由一组十六进制的字符构成&#xff0c;共12个字节。&#xff08;1个字节8位能表示2个十六进制数&#xff0c;12个字节能表示24个十六进制数&#xff09;。 ObjectId 是一个12字节 BSON 类型数据&#xff0c;有以下格式&#xff1a…

java objectid_关于MongoDB ObjectId

ObjectId的构成 ObjectId的值由12个字节组成&#xff0c;其中&#xff0c; 4个字节表示时间戳(自Unix纪元以来的秒数)&#xff0c;记录创建时间&#xff1b; 3个字节表示机器标识符&#xff0c;保证不同主机产生不同的ObjectId值&#xff1b; 2个字节表示进程ID&#xff0c;保证…

从根上理解MongoDB的ObjectId生成原理!

想写这篇文章好久了&#xff0c;一直抽不出时间。这两天端午节放假&#xff0c;我和娃都泡在图书馆&#xff0c;在他看书的空闲期&#xff0c;我拿出电脑写下了本文。 我们都知道&#xff0c;在分布式系统中&#xff0c;分布式 ID 有很多特殊的要求&#xff0c;其中之二就是要求…

ArcGIS中的OBJECTID、FID 和 OID 的区别!不要傻傻分不清

喜欢就关注我们吧 时常有很多我朋友分不清OBJECTID、FID 和 OID有什么区别&#xff0c;不懂得怎么应用和管理&#xff0c;今天我们来说个明白。 ArcGIS Desktop 产品要求独立表和属性表均具有 ObjectID字段&#xff0c;该字段包含唯一的长整型用于标识每个记录。 此 ID 由 Esri…

Mongo中id介绍

好记忆不如按烂笔头 &#xff0c;即便是最简单的&#xff0c;时间长了也难免会忘记&#xff0c;记下可以让你更明白。 2.6.6 _id和ObjectId MongoDB 中存储的文档必须有一个"_id" 键。这个键的值可以是任何类型的&#xff0c;默认是个ObjectId 对象。在一个集合里面…

canal

简介 canal [kənl]&#xff0c;译意为水道/管道/沟渠&#xff0c;主要用途是基于 MySQL 数据库增量日志解析&#xff0c;提供增量数据订阅和消费 早期阿里巴巴因为杭州和美国双机房部署&#xff0c;存在跨机房同步的业务需求&#xff0c;实现方式主要是基于业务 trigger 获取增…

阿里的数据同步神器——Canal

前言 同步数据的神器: Canal安装配置 canal [kə’nl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费 早期阿里巴巴因为杭州和美国双机房部署, 存在跨机房同步的业务需求, 实现方式主要是基于业务 trigger 获取增量变更。从 2…

使用Canal组件订阅MySQL binlog数据增量

一、简介 Canal是一款强大的开源组件&#xff0c;主要用途是基于 MySQL 数据库增量日志解析&#xff0c;提供增量数据订阅和消费。 1. canal 工作原理 canal 模拟 MySQL slave 的交互协议&#xff0c;伪装自己为 MySQL slave &#xff0c;向 MySQL master 发送dump 协议MySQ…

mysql进阶:canal搭建主从|集群架构

0.引言 之前我们讲解过canal的各种应用&#xff0c;但是对于生产环境来讲&#xff0c;服务高可用是必须保证的。因此canal单节点是不能满足我们的需求的。就需要搭建canal集群。 1. canal集群模式 从架构方式上出发&#xff0c;我们用来保证服务高可用的手段主要是主从架构、…

ElasticSearch 7.15.2 使用java canal 接入实现灵活化增量数据准实时同步

前言&#xff1a; ①canal.adapter-1.1.5 支持一对一单表的增量数据同步ElasticSearch 7&#xff1b; ②对于多表聚合场景的SQL满足不了我们的业务需求。 ③采用java canal 接入&#xff0c;可以实现灵活化增量数据准实时同步 文章目录 一、java canal 接入1. 依赖导入2. 增加配…

浅入浅出keepalived+mysql实现高可用双机热备

当数据库发生宕机的情况,如果配置了数据库主从同步模式或主主同步模式,则可以从从库中获取数据。 当数据库发生宕机的情况,要求应用系统实现高可用,应用系统不会受到影响,需要对mysql进行双机热备实现数据库的高可用。 实现双机热备的方式有Mycat组件方式、canel组件方式、…

【硬刚大数据】大数据同步工具之FlinkCDC/Canal/Debezium对比

欢迎关注博客主页&#xff1a;微信搜&#xff1a;import_bigdata&#xff0c;大数据领域硬核原创作者_王知无(import_bigdata)_CSDN博客 欢迎点赞、收藏、留言 &#xff0c;欢迎留言交流&#xff01;本文由【王知无】原创&#xff0c;首发于 CSDN博客&#xff01;本文首发CSDN论…

4、Canal的 instance模块

一、总体结构 如确所述&#xff0c;Canal server的模式有两种&#xff1a;manager和spring 在core模块中&#xff0c;定义了CanalInstance接口&#xff0c;以及其抽象类子类AbstractCanalInstance。 在spring模块&#xff0c;提供了基于spring配置方式的CanalInstanceWithSpr…

canal实现mysql数据同步

前言 canal是实现mysql数据备份,异地灾备,异地数据同步等重要的中间件,在实际的业务场景中有着广泛的使用,本文基于小编所在项目中一个异地数据同步的场景为例,通过案例演示下利用canal实现mysql数据同步的过程 同步原理 如上图所示,为canal同步mysql数据的原理的简单示…

SpringBoot系列之canal和kafka实现异步实时更新

SpringBoot系列之canal和kafka实现异步实时更新 实验开发环境 JDK 1.8SpringBoot2.2.1Maven 3.2+开发工具 IntelliJ IDEAsmartGit1、什么是阿里canal? canal是阿里开源的, 对数据库增量日志解析,提供增量数据订阅和消费的组件。引用官网的图片,canal的工作原理主要是模拟…

Java:SpringBoot整合Canal+RabbitMQ组合实现MySQL数据监听

canal [kə’nl]&#xff0c;译意为水道/管道/沟渠&#xff0c;主要用途是基于 MySQL 数据库增量日志解析&#xff0c;提供增量数据订阅和消费 目录 一、MySQL设置二、启动Canal服务端三、通过Canal客户端消费数据四、通过RabbitMQ消费数据1、启动RabbitMQ2、修改canal配置3、消…

Kubernetes 学习19基于canel的网络策略

一、概述 1、我们说过&#xff0c;k8s的可用插件有很多&#xff0c;除了flannel之外&#xff0c;还有一个流行的叫做calico的组件&#xff0c;不过calico在很多项目中都会有这个名字被应用&#xff0c;所以他们把自己称为project calico&#xff0c;但是很多时候我们在kubernet…