HyperLogLog(用于计算基数)

hyperLogLog的概述

Redis 中的HyperLogLog是用来做基数(在一个集合中,不重复的元素)统计的算法。

Redis的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定的。并且是很小的。

每个HyperLogLog键只需要花费12KB内存,就可以计算接近2^64个不同元素的基数。因为HyperLogLog只会根据输入元素来计算基数,而不会储存输入元素本身,所以HyperLogLog不能像集合那样,返回输入的各个元素

HyperLogLog命令

127.0.0.1:6379> pfadd ele java # 添加指定元素到HyperLogLog
(integer) 1
127.0.0.1:6379> pfadd ele c++ Cpp
(integer) 1
127.0.0.1:6379> pfadd python php
(integer) 1
127.0.0.1:6379> pfcount ele # 统计HyperLOgLOg中基数的总量
(integer) 3
127.0.0.1:6379> pfcount python
(integer) 1
127.0.0.1:6379> pfmerge ele1 ele python # 将两个Hyper的基数加入到另一个Hyper中
OK
127.0.0.1:6379> pfcount ele1
(integer) 4
127.0.0.1:6379> type ele1
string
127.0.0.1:6379> type ele
string
posted @   小罗要有出息  阅读(53)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
点击右上角即可分享
微信分享提示