用户画像利用BitMap存储

目前项目上存储利用BitMap进行存储,比如用户id 为1001,对应的标签id A1001,

setbit 1001 A1001,1 

在生产中经常会出现一个用户对应多个标签因此用BitMap存储的话就很方便

 

package com.demo.cn.Redis;

import java.util.BitSet;

public class BitSetUtils {


    /**
     * 将BitSet对象转化为ByteArray
     * @param bitSet
     * @return
     */
    public static byte[] bitSet2ByteArray(BitSet bitSet) {
        byte[] bytes = new byte[bitSet.size() / 8];
        for (int i = 0; i < bitSet.size(); i++) {
            int index = i / 8;
            int offset = 7 - i % 8;
            bytes[index] |= (bitSet.get(i) ? 1 : 0) << offset;
        }
        return bytes;
    }

    /**
     *
     * @param bytes
     * @return
     */
    public static BitSet byteArray2BitSet(byte[] bytes) {
        BitSet bitSet = new BitSet(bytes.length * 8);
        int index = 0;
        for (int i = 0; i < bytes.length; i++) {
            for (int j = 7; j >= 0; j--) {
                bitSet.set(index++, (bytes[i] & (1 << j)) >> j == 1 ? true
                        : false);
            }
        }
        return bitSet;
    }
}

 

package com.demo.cn.Redis;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.util.ArrayList;
import java.util.BitSet;
import java.util.List;
import java.util.ResourceBundle;

public class RedisUtil {

    private static ResourceBundle resourceBundle;

    static {
        resourceBundle = ResourceBundle.getBundle("redis_config");

        initPool();
    }
    private static volatile JedisPool jedisPool;
    public static Jedis getResource() {
        return jedisPool.getResource();
    }
    public static void returnResource(Jedis jedis) {
        jedisPool.returnResource(jedis);
    }

    public static void initPool() {
        if(jedisPool != null){
            return;
        }
        String host = resourceBundle.getString("redis.host");
        int port = Integer.parseInt(resourceBundle.getString("redis.port"));
        JedisPoolConfig config = config();
        jedisPool = new JedisPool(config,host,port);
    }

    private static JedisPoolConfig config() {
        JedisPoolConfig config = new JedisPoolConfig();
        return config;
    }

    public static void activeUser(long userId, String dateKey) {
        Jedis jedis= RedisUtil.getResource();
        try{
            jedis.setbit(dateKey,userId,true);
        }finally {
            RedisUtil.returnResource(jedis);
        }
    }

    //该天用户总数
    public static long totalCount(String dateKey) {
        Jedis jedis= RedisUtil.getResource();
        try{
            return jedis.bitcount(dateKey);
        }finally {
            RedisUtil.returnResource(jedis);
        }
    }

    //该天登录所有的用户id
    public static List<Long> activeUserIds(String  dateKey) {
        Jedis jedis= RedisUtil.getResource();
        try{

            if(jedis.get(dateKey)==null){
                return null;
            }
            BitSet set= BitSetUtils.byteArray2BitSet(jedis.get(dateKey).getBytes());

            List<Long>list=new ArrayList<Long>();
            for (long i=0;i<set.size();i++){
                if(set.get((int)i)){
                    list.add(i);
                }
            }
            return list;
        }finally {
            RedisUtil.returnResource(jedis);
        }
    }

    public static  List<Long> continueActiveUserCount(String... dateKeys) {
        Jedis jedis= RedisUtil.getResource();
        try{
            BitSet all = null;
            for (String key:dateKeys){
                if(jedis.get(key)==null){
                    continue;
                }
                BitSet set= BitSetUtils.byteArray2BitSet(jedis.get(key).getBytes());
                if(all==null){
                    all=set;
                }
                System.out.println(set.size());
                all.and(set);
            }
            List<Long>list=new ArrayList<Long>();
            for (long i=0;i<all.size();i++){
                if(all.get((int)i)){
                    list.add(i);
                }
            }
            return list;
        }finally {
            RedisUtil.returnResource(jedis);
        }
    }


    public static void main(String[]args){
        Jedis jedis= RedisUtil.getResource();
        RedisUtil.returnResource(jedis);

        System.out.println(jedisPool);

        activeUser(10003,"20180926");
        List<Long> list=activeUserIds("20180925");
        for(Long i:list){
            System.out.println("the userid :"+i);
            System.out.println(totalCount("20180925"));
        }


    }
}

Redis的存储结果

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值