Setbit 的实际应用
场景: 1亿个用户, 每个用户 登陆/做任意操作 ,记为 今天活跃,否则记为不活跃
每周评出: 有奖活跃用户: 连续7天活动,每月评,等等。 思路:
Userid dt active
1 2013-07-27 1
1 2013-0726 1 如果是放在表中, 1:表急剧增大,2:要用group ,sum运算,计算较慢
用: 位图法 bit-map
Log0721: ‘011001...............0’ //一天:1,2,5号用户登陆了
......
log0726 : ‘011001...............0’ //1,2,5号用户登陆了
Log0727 : ‘0110000.............1’ 1: 记录用户登陆:
每天按日期生成一个位图, 用户登陆后,把user_id位上的bit值置为1 2: 把1周的位图 and 计算, 各位都为1的,即是连续登陆的用户 redis 127.0.0.1:6379> setbit mon 100000000 0
(integer) 0
redis 127.0.0.1:6379> setbit mon 3 1
(integer) 0
redis 127.0.0.1:6379> setbit mon 5 1
(integer) 0
redis 127.0.0.1:6379> setbit mon 7 1
(integer) 0
redis 127.0.0.1:6379> setbit thur 100000000 0
(integer) 0
redis 127.0.0.1:6379> setbit thur 3 1
(integer) 0
redis 127.0.0.1:6379> setbit thur 5 1
(integer) 0
redis 127.0.0.1:6379> setbit thur 8 1
(integer) 0
redis 127.0.0.1:6379> setbit wen 100000000 0
(integer) 0
redis 127.0.0.1:6379> setbit wen 3 1
(integer) 0
redis 127.0.0.1:6379> setbit wen 4 1
(integer) 0
redis 127.0.0.1:6379> setbit wen 6 1
(integer) 0
redis 127.0.0.1:6379> bitop and res mon feb wen
(integer) 12500001 如上例,优点:
1: 节约空间, 1亿人每天的登陆情况,用1亿bit,约1200WByte,约10M 的字符就能表示
2: 计算方便

最新文章

  1. Linux中SysRq的使用(魔术键)
  2. java cookie 工具类
  3. 教你分分钟学会用python爬虫框架Scrapy爬取心目中的女神
  4. linux环境初始化 用户问题
  5. win下隐藏任务栏
  6. TextBox仿Foxmail收件人删除效果
  7. 用inno Setup制作web项目安装包
  8. SQL的集合运算符介绍
  9. 基于R语言的梯度推进算法介绍
  10. jmeter-Java-MongoDB 数据库增删改查操作
  11. D5 LCA 最近公共祖先
  12. 转发 C# Win32 API程序控制鼠标的操作
  13. 日系插画学习笔记(一):SAI软件基础
  14. 由js文件中引入另外的js文件想到的
  15. lua rc4算法实现
  16. c# RSA 加密解密 java.net公钥私钥转换 要解密的模块大于128字节
  17. VNC的安装和常用命令
  18. s12-day01-work02 python多级菜单展示
  19. ssm 注解@ResponseBody 返回json 乱码问题
  20. C++中使用内存映射文件处理大文件

热门文章

  1. py 爬取页面http://m.sohu.com 并存储
  2. TeraTerm设定(解决日文乱码问题)
  3. Xcode打包应用为ipa
  4. MarsEdit 快速插入代码
  5. 使用 ftrace 调试 Linux 内核,第 3 部分
  6. maven自动导入包失败
  7. eopkg命令
  8. gcc、arm-Linux-gcc和arm-elf-gcc的组成及区别
  9. IO重定向
  10. 临远的spring security教程