redis的bitmap实现用户签到天数统计

我们知道 redis中的bitmap对应有二的三十二次幂个bit位,我们们统计每个用户当前月的 每一天的是否签到,我们只需要把月份跟bit位进行 对应,比如现在是 2021年的10月,我们把10月1号当天是否签到对应第一个bit位,签到了把对应bit位改为1,没有签到,就使用原始数字0,这样就能完成签到功能

签到功能代码

我们把 10月第1天 第四天 第五天 第21天 22天的bit位都设置为1,代表着签到 ,在我们的 图形化界面中 是从左往右看的

我们可以看到 第0 号位 3 4 20 21号位都设置为1了,因为设置的时候是 从0号位开始,我们得到当天的天数之后,需要减一 天数,才是对应的bit位

对应的代码如下

统计签到天数

我们统计签到天数的话,以10月为例子,我们统计从10月1号到今天10月22号的签到天数的话

1.首先获得本月的第几天

2.然后把获得到的redis的对应的 bitmap的值拿出来,按位与上1,如果最后一位是1,则代表签到过,那么就把计数器加一

3.如果按位与是0,那就代表着 今天没签到

4.做完这些动作之后,再把bitmap的值拿出来,向右移动一位,这样每次按位与 1的话得到的都是上一天的是否签到

代码如下

java 复制代码
    @Test
//查看用户连续签到天数
    public void redisBitMapTest2(){
        //获取到 本月的第几天
        int dayOfMonth = LocalDateTime.now().getDayOfMonth();
        String format = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM"));

        BitFieldSubCommands bitFieldSubCommands = BitFieldSubCommands.create().get(BitFieldSubCommands.BitFieldType.unsigned(dayOfMonth )).valueAt(0);
        List<Long> list1 = stringRedisTemplate.opsForValue()
                .bitField(RedisConstants.USER_SIGN_KEY + 1 + format, bitFieldSubCommands);
        Long l = list1.get(0);
        System.out.println(l);
        String binaryNumber =   Long.toBinaryString(l);
        System.out.println("十进制数字 " + l+ " 的二进制表示为: " + binaryNumber);
        int count=0;
        while (dayOfMonth>0){
    if((l&1)==0){
      dayOfMonth--;
    }else {
        count++;
    }
    l=l>>>1;
}
        System.out.println(count);
    }

具体的bitmap的redis的api大家可以自行百度

运行结果如下

最后打印的count的值为5,也就是说 跟我们之前设置的签到次数是一样的

相关推荐
kngines9 分钟前
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】附录-D. 扩展插件列表(PostGIS/PostgREST等)
数据库·postgresql·数据分析·pgvector·扩展插件·postgrest·向量数据
星星点点洲20 分钟前
【Redis】谈谈Redis的设计
数据库·redis·缓存
HelloZheQ21 分钟前
MVCC:数据库并发控制的利器
服务器·数据库·oracle
珹洺33 分钟前
Jsp技术入门指南【十四】实现基于MySQL+JDBC+JSP数据库验证的登录界面与登录跳转功能
java·运维·数据库·mysql·servlet
JhonKI41 分钟前
【MySQL】日志缓冲区详解 以及 InnoDB内存结构总结
数据库·mysql·oracle
vvilkim1 小时前
MySQL视图:虚拟表的强大功能与应用实践
数据库·mysql
tangjunjun-owen1 小时前
Milvus 2.4 使用详解:从零构建向量数据库并实现搜索功能(Python 实战)
数据库·python·milvus·rag
GalenZhang8881 小时前
langchain4j中使用milvus向量数据库做RAG增加索引
数据库·milvus
闪电麦坤952 小时前
思路解析:第一性原理解 SQL
服务器·数据库·sql
珹洺2 小时前
数据库系统概论(八)SQL单表查询语言超详细讲解(附带例题表格对比带你一步步掌握)
数据库·sql